数组中出现次数超过一半的数字

数组中出现次数超过一半的数字

https://www.nowcoder.com/practice/e8a1b01a2df14cb2b228b30ee6a92163?tpId=117&tags=&title=&diffculty=0&judgeStatus=0&rp=1&tab=answerKey

//对数组同时去掉两个不同的数字 如果存在结果 那么最后剩下的一定是答案。最后一步需要判断最后剩下的是否满足超过一半 如果不满足就说明不存在,如果存在的话,就一定会满足。

public int MoreThanHalfNum_Solution(int [] array) {
        if(array==null) return 0;
        int count = 1;
        int pre = array[0];
        for(int i=1;i<array.length;i++){
            if(array[i]==pre){
                count++;
            }else{
                count--;
                if(count==0){
                    if(i+1<array.length){
                        pre = array[i+1];
                        count = 1;
                    }else return 0;
                }
            }
        }
        int cnt =0;
        //判断最后剩下的输是否满足次数超过一半
        for(int i=0;i<array.length;i++){
            if(pre==array[i]){
                cnt++;
            }
        }
        if(cnt>array.length/2) return pre;
        return 0;
    }
全部评论

相关推荐

07-11 22:27
中南大学 Java
程序员牛肉:学历的话没问题。但是没问题的也就只有学历了。 其实你的整体架构是正确的,博客接着干。但是项目有点过于简单了。从后端的角度上讲,你这也就是刚入门的水平,所以肯定约面试够呛。 如果你要应聘后端岗位,那你第一个项目竟然是仿写操作系统。这个你要面试官咋问你。你一定要记住一点,你简历上写的所有的东西,都是为了证明你有能力胜任当前的岗位,而不是为了证明你自己会什么。 如果你只是浅浅的做几个项目,描述也都是烂大街。技术点也都是各种混水类的配置类需求,那你就不要幻想自己能走多远。一定要保持思考,保持学习。
点赞 评论 收藏
分享
07-28 16:15
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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