剑指offer——28.数组中出现次数超过一半

来源:互联网 发布:qq盗号软件 编辑:程序博客网 时间:2024/06/05 15:52

题目描述

数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。

代码

思路:可以使用map数据结构,但因为牛客系统不识别es6,所以就使用对象来存储每个元素出现次数。

function MoreThanHalfNum_Solution(numbers){    // write code here       var obj={};    var len = numbers.length;    numbers.map(function(num){        if(obj[num]){            obj[num]++        }else{            obj[num]=1;        }    })    for (var i in obj){        if(obj[i]>Math.floor(len/2)) return i    }    return 0;}
阅读全文
0 0
原创粉丝点击