当前位置:网站首页>20220523搜索和排序:搜索旋转排序数组
20220523搜索和排序:搜索旋转排序数组
2022-08-09 02:37:00 【丿SeeYouAgain】
题目描述:整数数组 nums
按升序排列,数组中的值 互不相同 。在传递给函数之前,nums 在预先未知的某个下标 k(0 <= k < nums.length)上进行了 旋转,使数组变为 [nums[k], nums[k+1], ..., nums[n-1], nums[0], nums[1], ..., nums[k-1]](下标 从 0 开始 计数)。例如, [0,1,2,4,5,6,7] 在下标 3 处经旋转后可能变为 [4,5,6,7,0,1,2] 。给你 旋转后 的数组 nums
和一个整数 target
,如果 nums
中存在这个目标值 target
,则返回它的下标,否则返回 -1
。
编码实现:
public int search(int[] nums, int target) {
int left = 0, right = nums.length - 1;
int mid = -1;
while(left <= right){
mid = left + (right - left) / 2;
if(target == nums[mid]){
return mid;
}
if(nums[mid] >= nums[left]){
if(target < nums[mid] && target >= nums[left]){
right = mid - 1;
}else{
left = mid + 1;
}
}else{
if(target > nums[mid] && target <= nums[right]){
left = mid + 1;
}else{
right = mid - 1;
}
}
}
return -1;
}
边栏推荐
猜你喜欢
随机推荐
Working subtotal rtcp length and network byte order
C#计算两个时间相差多少天、时、分、秒
【电商运营】不知道怎么做网站优化?这里有你需要知道的一切!
为什么应用程序依赖关系映射对于云迁移至关重要
【剑指offer65】不适用加减乘除做加法
eladmin container deployment super detailed process
[Redis] The core principle of master-slave replication
LintCode 283. 三数之中的最大值
数仓第二篇: 数据模型(维度建模)
Open3D 均匀采样
图论相关知识
数字 06 verilog_关于异步FIFO
10.1-----19. Delete the Nth node from the bottom of the linked list
2.1-----27. Remove elements
Force buckled brush problem record 7.1 -- -- -- -- -- 707. The design list
C#计算SHA1加密和base64编码
Pytest+request+Allure实现接口自动化框架
2022 Eye Health Brand Franchise Exhibition, Beijing Vision Care Exhibition, China Ophthalmology Technology Summit
Json之JArray的使用方法
攀爬倒影发光方块