数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。
你可以假设数组是非空的,并且给定的数组总是存在多数元素。
示例:
输入: [1, 2, 3, 2, 2, 2, 5, 4, 2]
输出: 2
限制:
1 <= 数组长度 <= 50000
解题:
/**
* @param {number[]} nums
* @return {number}
*/
var majorityElement = function(nums) {
var targetLength = nums.length / 2;
var numLength = nums.length;
var targetNum;
var obj = {};
for (var i = 0; i < numLength; i++) {
targetNum = nums[i];
obj[targetNum] ? obj[targetNum]++ : (obj[targetNum] = 1);
if (obj[targetNum] > targetLength) break;
}
return targetNum;
};
结果:

脚踏实地行,海阔天空飞~
156

被折叠的 条评论
为什么被折叠?



