标签:-- linkedin integer exist 空间复杂度 white sel www. ret
给定一个整型数组,找出主元素,它在数组中的出现次数严格大于数组元素个数的二分之一。
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; } };
标签:-- linkedin integer exist 空间复杂度 white sel www. ret
原文地址:http://www.cnblogs.com/ygtzds/p/7481757.html