
前言
今天的题目
昨天的题解
题目
每天一道剑指offer-数组中出现次数超过一半的数字
题目详述
数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}。由于数字2在数组中出现了5次,超过数组长度的一半,因此输出2。如果不存在则输出0。
题目详解
思路
使用一个计数count = 1,当前数num,每当数组中数和当前数num相同,那么count就加1,不相同就减一,因为是找出现的数超过数组的长度的一半,所以最后如果有出现的数超过数组长度一半的,count肯定是大于0的数
代码
代码截图(避免乱码)

结束语
作者乔戈里亲历2019秋招,哈工大计算机本硕,百度java工程师,欢迎大家关注我的微信公众号:程序员乔戈里,公众号有3T编程资源,以及我和我朋友(百度C++工程师)在秋招期间整理的近200M的面试必考的java与C++面经,并有每天一道leetcode打卡群与技术交流群,欢迎关注。
寻找数组中的多数元素
本文介绍了一种高效算法,用于从数组中找到出现次数超过数组长度一半的数字。通过一个计数器和当前数的概念,文章详细解释了算法的原理,并提供了具体的代码实现。
172万+

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



