数字在升序数组中出现的次数_JAVA_中等

数字在升序数组中出现的次数

http://www.nowcoder.com/questionTerminal/70610bf967994b22bb1c26f9ae901fa2

初始解法

  • 二分法查找上界(k值)与下界(k值),相减得到个数
public class Solution {
    public int GetNumberOfK(int [] array , int k) {
        int start = 0, end = array.length - 1, result = 0, kStart = 0, kEnd = array.length - 1;
        // 找该值左端点
        while(start <= end){
            kStart = (start + end) / 2;
            if(k == array[kStart] && (kStart == 0 || kStart == array.length - 1 || array[kStart - 1] != k)) {
                break;
            } else if(k <= array[kStart]) {
                end = kStart - 1;
            } else {
                start = kStart + 1;
            }
        }
        // 未找到
        if(start > end) {
            return 0;
        }

        // 找该值右端点
        start = kStart;
        end = array.length - 1;
        while(start <= end){
            kEnd = (start + end) / 2;
            if(k == array[kEnd] && (kEnd == 0 || kEnd == array.length - 1 || array[kEnd + 1] != k)) {
                break;
            } else if(k < array[kEnd]) {
                end = kEnd - 1;
            } else {
                start = kEnd + 1;
            }
        }
        return kEnd - kStart + 1;
    }
}

优化解法

  • 下界是k值(存在)或者是比k值大的值(不存在),上界是比k值大的值
  • temp = (start + end - start) / 2可以保证start和end相邻时取start而不影响其他情况
  • 由上,左侧增长而右侧不增长既不会死循环也就可以保证结果偏大
public class Solution {
    public int GetNumberOfK(int [] array , int k) {
        int start = 0, end = array.length, result = 0, kStart = 0, kEnd = array.length;
        // 找该值左端点
        while(start < end){
            kStart = start + (end - start) / 2;
            if(k <= array[kStart]) {
                end = kStart;
            } else {
                start = kStart + 1;
            }
        }
        kStart = start;

        // 找该值右端点
        start = 0;
        end = array.length;
        while(start < end){
            kEnd = start + (end - start) / 2;
            if(k < array[kEnd]) {
                end = kEnd;
            } else {
                start = kEnd + 1;
            }
        }
        kEnd = start;
        return kEnd - kStart;
    }
}
全部评论

相关推荐

找个工作&nbsp;学历是要卡的&nbsp;要求是高的&nbsp;技能不足是真的&nbsp;实习经验是0的&nbsp;简历无处可写是事实的&nbsp;钱不好赚是真的&nbsp;想躺平又不敢躺&nbsp;也不甘心躺&nbsp;怕自己的灵感和才华被掩埋甚至从未被自己发现&nbsp;又质疑自己是否真正有才华
码农索隆:你现在啊,你心里都明白咋回事,但是你没办法改变现状,一想到未来,你又没有信心狠下心来在当下努力。 得走出这种状态,不能一直困在那里面,哪不行就去提升哪,你一动不动那指定改变不了未来,动起来,积少成多才能越来越好
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
06-29 17:30
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务