单选题

旋转数组是一种常见的数据结构问题,通常是指一个有序数组经过旋转后,使得所有元素逆序排列。整数 数组 nums 按升序排列,数组中的值互不相同。

在预先未知的某个下标 k(0 <= k < nums.length)上进行了旋转,使 数组变为 [nums[k], nums[k + 1],..., nums[n - 1], nums[0], nums[1],..., nums[k - 1]](下标从 0 开始计数)。 现在给定旋转后的数组 nums 和一个整数 target,如果 nums 中存在这个目标值 target,则返回它的下标,否则返回 -1。 

下面程序中()处应填入的程序是:例如,给定一个数组 [4,5,6,7,0,1,2],它可能经过旋转变为 [0,1,2,4,5,6,7]。二分查 找算法搜索旋转排序数组的程序,下面横线中,应填入的一行或多行代码是(    )


def search(nums, target):

      left, right = 0, len(nums) - 1


      while left <= right:

            mid = (left + right) // 2

            if nums[mid] == target:

                  return True


            if nums[mid] > nums[right]:

                  if nums[mid] > target or nums[left] <= target:

                        right = mid - 1

                  else:

                        left = mid + 1

            elif nums[mid] < nums[right]:

                  _________________________

            else:

                  right -= 1

      return False

A

if nums[mid] < target or nums[right] >= target:

      lleft = mid - 1

else:

      lright = mid + 1

B

if nums[mid-1] < target and nums[right+1] >= target:

      left = mid + 1

else:

      right = mid - 1

C

if nums[mid] < target or nums[right] >= target:

      lleft = mid

else:

      lright = mid

D

if nums[mid] < target and nums[right] >= target:

      lleft = mid + 1

else:

      lright = mid - 1

赣ICP备20007335号-2