Search in Rotated Sorted Array

来源:互联网 发布:韩国抄袭知乎 编辑:程序博客网 时间:2024/06/15 10:24

Search in Rotated Sorted Array

https://leetcode.com/problems/search-in-rotated-sorted-array/description/

public int search(int[] nums, int target) {        int low = 0;        int high = nums.length - 1;        while(low <= high){            int mid = (low + high)/2;            if(nums[mid] == target) return mid;            //ex: 1, 3, 4, 5 , 7, 9 --> 7, 9, 1, 3, 4, 5            // 如果旋转后, 左边递增的元素的个数 < 右边递增的个数            else if(nums[low] > nums[mid]){                // 在这种if情况下,右半边都是递增的,如果target满足这些条件,就便于二分查找,所以选择右半边                if(target > nums[mid] && target < nums[low]) low = mid+1;                 否则的话,就选择左半边                else high = mid;            }            // 1, 3, 4, 5, 7, 9 --> 4, 5, 7, 9, 1, 3            else{                if(target < nums[mid] && target >= nums[low]) high = mid;                else low = mid + 1;            }        }        // 总结:在这样的数组中,总能找到半部分是递增的,如果target能在这里面,就能进行正常的二分查找;否则的话就到另一半里面;另一半里面也总能找到半部分是递增的,...... 如此迭代下去,就能看到target是否存在或者它的index。        return -1;    }
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 人胖跑步跑不动怎么办 不工作每天很累怎么办 电大本科文凭毕业证掉了怎么办 要求全日制本科自考本科怎么办 毕业证被学校扣了怎么办 自考本科档案没有密封怎么办 艺术生统考没过怎么办 本科科目没考过怎么办 军校体检条丢了怎么办 学美术考了大专怎么办 音基试唱音不准怎么办 音基证书丢了怎么办 职称计算机证书丢了怎么办 30岁了 开始怀旧怎么办 31岁了 缺乏运动怎么办 30多了还一事无成未来怎么办 导师说名额已满怎么办 在中国想当大官怎么办 站久了小腿变粗怎么办 苹果x锁屏延迟怎么办 被扇了巴掌耳痛怎么办 被扇了巴掌耳鸣怎么办 水兵舞不会扭胯怎么办 我的字写得很丑怎么办 二年级学生不会造句怎么办 w10下载种子文件失败怎么办 宝宝挂水手肿了怎么办 lol有英雄皮肤没英雄怎么办 qq聊天图标粉色钥匙怎么办 和舍友相处不来怎么办 被舍友偷了东西怎么办 体育生没过线怎么办 户主去世房产不能过户怎么办 苍蝇飞到嘴唇上怎么办 苍蝇不小心碰到嘴唇了怎么办 苍蝇老往身上飞怎么办 单位乒乓球比赛有领导参加怎么办 意外看到别人打野战怎么办 骨盆低想顺产要怎么办 右胯比左胯突出怎么办 一岁宝宝骨盆不对称怎么办