查找数组中所有目标数值

问题

Given an array of integers sorted in ascending order, find the starting and ending position of a given target value.

Your algorithm's runtime complexity must be in the order of O(log n).

If the target is not found in the array, return [-1, -1].

For example,
Given [5, 7, 7, 8, 8, 10] and target value 8,
return [3, 4].

思路

简单的二分查找,由于有相同的元素,需要后面加了几个把附近的找出来。
ps:之前在公司项目也这样找过一次,不过要先排序再查找。

代码(越写越觉得不对劲,写的太冗余了,勉强ac)

class Solution {
    public int[] searchRange(int[] nums, int target) {
        //升序 找到起始的位置;原始的二分查找,再找旁边的几个。
        int[] find = new int[2];
        find[0]=-1;find[1]=-1;
        if(nums.length==0)
            return find;
        int result =binarySearch(0,nums.length-1,nums,target);
        if(result == -1)
            return find;
        else
           return findNearBy(result,target,nums);
            
            
    }
    public int binarySearch(int start,int end,int[] nums,int target){
        if(start>end){
            return -1;
        }
        int mid = (start+end)/2;
        if(nums[mid] == target){
            return mid;
        }
        if(target>nums[mid]){ //右边
            return  binarySearch(mid+1,end,nums,target);
        }else{
           return binarySearch(start,mid-1,nums,target);
        }
    }
    public int[] findNearBy(int index,int target,int[]nums){
        
        int start = index; int end =index;
        while(start>0){  //注意溢出  这里index=0没有算到,要后面判断一次
            if(nums[start]==target){
                start--;
            }else{
                break;
            }
        }
        // if(start ==0){   //0的情况
            if(nums[start]!=target){
                start = start+1;
            }
        // }
        while(end<nums.length-1){
            if(nums[end]==target){
                end ++;
            }else break;
        }
        // if(end == nums.length-1){  //length-1
            if(nums[end] != target){
                end = end-1;
            }
        // }
        int[] temp = new int[2];
        temp[0] = start;
        temp[1] = end;
        return temp;
        
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容

  • 今天好不容易做完了一个功能的开发,离下班尚有一段时间,心情大好。 结果在提交到服务器的过程中,手比脑子快的点击了u...
    心心_幸会阅读 180评论 0 2
  • (1) 小时候最大的梦想就是去北京上学。北京对于一个不发达地区的4,5线的县城市来说是...
    失人苑阅读 350评论 0 1
  • 生者必死,聚者必散,荣者必枯。 年年得知青添色,哪知百年木已腐根生。 年少不知愁滋味,却道百人愁里无他相。 如今方...
    堆雪风流阅读 410评论 0 4
  • 一晌贪欢入金城 热浪腾空 万里云洁白 东流的河水 冲荡着断桥 漂浮着的羊皮筏子 是你苍老的记忆 穿梭的游艇 向世界...
    浩宇_90阅读 149评论 0 0
  • 上完夜班,爬完楼,感触颇深,先来晨读吧。 001注意力 看完之后,想到一件比较有喜感的事情,大学期间,跟宿舍好友相...
    浊酒一壶慰风尘阅读 148评论 10 8