leetcode 7. 在有序可重复数组旋转后搜索 Search in Rotated Sorted Array II

Search in Rotated Sorted Array II

Follow up for "Search in Rotated Sorted Array":
What if duplicates are allowed?

Would this affect the run-time complexity? How and why?

Write a function to determine if a given target is in the array.

解题思路:
本题基于leetcode 6. 在有序数组旋转后搜索 Search in Rotated Sorted Array,允许有序数组中存在重复。
与上一题(不允许重复)的不同是
nums[m] > nums[l] : (l, m-1)单增
nums[m] <= nums[l] : (m+1, r)不一定单增,因为{1,3,1,1,1} 或{1,1,1,3,1}

此时,可以将上述条件分开来看
nums[m] < nums[l] : (m+1, r)一定单增
num[m] == nums[l] : 将 l+1,重新递归计算 (当[l, r],将 r-1

class Solution {
public:
    //nums 数组边界为 [l,r)
    bool searchR(vector<int>& nums,int l, int r, int target) {
        if (r <= l)
            return false;
        int m = (l+r) / 2;
        if (nums[m] == target)
            return true;

        if (nums[l] < nums[m]) {
            if (target >= nums[l] && target < nums[m])
                return searchR(nums, l, m, target);
            else
                return searchR(nums, m+1, r, target);
        } else if (nums[l] > nums[m]) {
            if(target > nums[m] && target <= nums[r-1])
                return searchR(nums, m+1, r, target);
            else
                return searchR(nums, l, m, target);    
        } else {
            return searchR(nums, ++l, r, target);    

        }
    }

    bool search(vector<int>& nums, int target) {
        return searchR(nums, 0, nums.size(), target);
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值