通过在 Python 中交换连续索引对来查找数组的程序


假设我们有一个名为 nums 的数字列表,我们必须通过将每个连续偶数索引互换,并将每个连续奇数索引互换来返回列表。

因此,如果输入像 nums = [8,5,3,4,8,9,3,6,4,7],则输出将为 [3, 4, 8, 5, 3, 6, 8, 9, 4, 7]

为了解决这个问题,我们将遵循以下步骤 −

  • 对于 i 从 0 到 nums 的大小 - 2,增加 4,执行
    • 如果 i + 2 < nums 的大小,则
      • 交换 nums[i] 和 nums[i + 2]
    • 如果 i + 3 < nums 的大小,则
      • 交换 nums[i + 1] 和 nums[i + 3]
  • 返回 num

例子

让我们看看以下实现以获得更好的理解 −

def solve(nums):
   for i in range(0, len(nums) - 2, 4):
      if i + 2 < len(nums):
         nums[i], nums[i + 2] = nums[i + 2], nums[i]
      if i + 3 < len(nums):
         nums[i + 1], nums[i + 3] = nums[i + 3], nums[i + 1]

   return nums

nums = [8,5,3,4,8,9,3,6,4,7]
print(solve(nums))

输入

[8,5,3,4,8,9,3,6,4,7]

输出

[3, 4, 8, 5, 3, 6, 8, 9, 4, 7]

更新于: 2021-10-14

388 次浏览

开启你的职业生涯

通过完成课程获得认证

开始学习
广告