上海鹭城建设集团网站,传奇霸业网页游戏开服,模板网站建设一条龙,做网站运营需要具备什么能力已知存在一个按非降序排列的整数数组 nums #xff0c;数组中的值不必互不相同。
在传递给函数之前#xff0c;nums 在预先未知的某个下标 k#xff08;0 k nums.length#xff09;上进行了 旋转 #xff0c;使数组变为 [nums[k], nums[k1], …, nums[n-1], nu…已知存在一个按非降序排列的整数数组 nums 数组中的值不必互不相同。
在传递给函数之前nums 在预先未知的某个下标 k0 k nums.length上进行了 旋转 使数组变为 [nums[k], nums[k1], …, nums[n-1], nums[0], nums[1], …, nums[k-1]]下标 从 0 开始 计数。例如 [0,1,2,4,4,4,5,6,6,7] 在下标 5 处经旋转后可能变为 [4,5,6,6,7,0,1,2,4,4] 。
给你 旋转后 的数组 nums 和一个整数 target 请你编写一个函数来判断给定的目标值是否存在于数组中。如果 nums 中存在这个目标值 target 则返回 true 否则返回 false 。
示例 1
输入nums [2,5,6,0,0,1,2], target 0 输出true
解题思路
分成3钟情况讨论 7 8 9 1 2 3 4 5 6 nums[l]1 nums[mid]3 nums[l]nums[mid] 所以只要tar处于nums[l]tarnums[mid]中直接在[l,mid-1]区间内查找 7 8 9 1 2 3 4 5 6 nums[l]7 nums[mid]3 nums[l]nums[mid] 所以只要tar处于nums[mid]tarnums[r]中直接在[mid1,r]区间内查找 3. 1 8 9 1 2 3 4 5 6 nums[l]nums[mid]1 nums[l]nums[mid] l 缩小搜索范围
代码
class Solution {public boolean search(int[] nums, int target) {int l0,rnums.length-1;while (lr){int mid(r-l)/2l;if(nums[mid]target) return true;if(nums[l]nums[mid]) {l;continue;}else if(nums[l]nums[mid])//前半部分是有序的{if(targetnums[mid]targetnums[l])rmid-1;else lmid1;}else {if(targetnums[mid]targetnums[r])lmid1;else rmid-1;}}return false;}
}