lintcode.46 主元素
Posted 会飞的雅蠛蝶
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了lintcode.46 主元素相关的知识,希望对你有一定的参考价值。
给定一个整型数组,找出主元素,它在数组中的出现次数严格大于数组元素个数的二分之一。
注意事项
You may assume that the array is non-empty and the majority number always exist in the array.
样例
给出数组[1,1,1,1,2,2,2],返回 1
挑战
要求时间复杂度为O(n),空间复杂度为O(1)
这道题要求O(n),肯定是遍历一遍出结果。然而主元素一定大于长度的一半。由此,主元素减去其他所有数的数量还是会大于0。
class Solution { public: /* * @param nums: a list of integers * @return: find a majority number */ int majorityNumber(vector<int> &nums) { // write your code here int s=nums.size(); int res=nums[0]; int cnt=1; for(int i =1;i<s;i++) { if(res==nums[i]) cnt++; else cnt--; if(cnt<=0){ res=nums[i]; cnt=0; } } return res; } };
以上是关于lintcode.46 主元素的主要内容,如果未能解决你的问题,请参考以下文章