第一次见到这个题,感觉简单到爆,不就是sort函数排个序,取中位数,遍历一遍计个数不就OK了吗?但是面试时,sort可能会让你自己去实现,或者说,题目要求:不能修改输入的数组呢???
第一种方法(基于Partition函数)
注意:此方法修改了输入的数组
核心:出现次数超过一半的数字,排序后中位数肯定是这个数字
解题思路:通过Partition函数,随机选出数组中的一个元素(我的代码中默认是数组中第一个元素),并且通过快排的思想,小的元素移到随机值前面,大的元素移到随机值的后面,然后返回随机值最后的位置。然后通过调用Partition函数,用返回的index值和中值判等,如果index>mid,说明中位数在左边,end=mid-1,如果index 第二种方法(计数法) 核心:出现次数超过一半的数字个数比其他所有数字个数至少多一 解题思路:从首位开始(result==numbers[0]),遇到相等的元素,count++,遇到不相等的元素,count--,当count==0时,result重新赋值为当前元素,重新给count赋值为1,直到数组遍历完之后,返回result 疑惑???既然,判断出来了,为什么还要调用Check函数,因为我们无法判断result是否为出现次数最多的元素,就算是出现次数最多的元素,不知是否超过数组一半,例如:{5,5,5,5,5,3,3,3,4,4,4,4} {3,3,3,4,4,4,4,5,5,5,5,5} 另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。class Solution {
public:
int MoreThanHalfNum_Solution(vector
注意:此方法没有修改输入的数组class Solution {
public:
int MoreThanHalfNum_Solution(vector
当前标题:数组中出现次数超过一半的数字(C++剑指Offer详解)-创新互联
本文URL:http://cdweb.net/article/djjeci.html