题解 | #数组中出现次数超过一半的数字#

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

https://www.nowcoder.com/practice/e8a1b01a2df14cb2b228b30ee6a92163

一个数字出现的次数超过数组长度的一半<=>这个数字出现的次数可以抵消所有其它数字出现的次数
首先对elem=a[0]进行计数cnt=1, 当后面a[i]为elem时,就cnt++,否则cnt--,当cnt减为0时,从elem=a[i]重复前面的动作。
这样最终所求数字只可能是elem或者不存在。
class Solution {
public:
    int MoreThanHalfNum_Solution(vector<int> vec) {
		if (vec.empty())
		{
			return 0;
		}
		
		int cnt = 1;
		int elem = vec[0];
		for (int i = 1; i < vec.size(); ++i)
		{
			if (vec[i] == elem)
			{
				cnt++;
			}
			else
			{
				cnt--;
				if (cnt == 0)
				{
					elem = vec[i];
					cnt = 1;
				}
			}
		}
		
		cnt = 0;		
		for (int i = 0; i < vec.size(); ++i)
		{
			if (vec[i] == elem)
			{
				cnt++;
			}
		}
		
		if (cnt > vec.size() / 2)
		{
			return elem;
		}
		
		return 0;	
    }
};


全部评论

相关推荐

06-18 15:03
门头沟学院 Java
至少实习看起来比去年好?问了下群里的同学和身边的同学,人均有offer。有的还有好几个大厂offer
菜鸟1973:上一年暑期也是人均大厂实习offer,结果秋招跟不招人一样,大部分都转正了
点赞 评论 收藏
分享
風に薫る:前阵子把一个面试时老托腮抖腿的挂了 太松弛真不行
点赞 评论 收藏
分享
mama3925:建议专业技能里测试移到最上面,加粗。然后适当加入些自动化测试工具。第二个项目,第三条亮点最后错别字。然后佬如果对自己很自信的话,可以项目放前面,然后项目里可以编造点测试经历,写在写在项目亮点的前两行。最后可加个自我评价,放个博客或者仓库链接
点赞 评论 收藏
分享
评论
3
3
分享

创作者周榜

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