Given an array of size n, find the majority element. The majority element is the element that appears more than ⌊ n/2 ⌋ times.

You may assume that the array is non-empty and the majority element always exist in the array.

需要注意的是:这道题只是要找出多数元素,已经默认存在多数元素了,而不需要去判断是否存在多数元素。之前的思路就一直卡在怎么判断多数元素存的的问题上了。

思路解析:

1. 初始化majorityIndex,并且维护其对应count;

2. 遍历数组,如果下一个元素和当前候选元素相同,count加1,否则count减1;

3. 如果count为0时,则更改候选元素,并且重置count为1;

4. 返回A[majorityIndex]

原理:如果majority元素存在(majority元素个数大于n/2,个数超过数组长度一半),那么无论它的各个元素位置是如何分布的,其count经过抵消和增加后,最后一定是大于等于1的。 如果不能保证majority存在,需要检验。 复杂度:O(N)

Attention: 循环时从i = 1开始,从下一个元素开始,因为count已经置1

C++版:

class Solution {
public:
int majorityElement(vector<int> &num) { int elem = ;
int count = ; for(int i = ; i < num.size(); i++) { if(count == ) {
elem = num[i];
count = ;
}
else {
if(elem == num[i])
count++;
else
count--;
} }
return elem;
}
  };

Python版:

class Solution:
# @param {integer[]} nums
# @return {integer}
def majorityElement(self, nums):
lenth=len(nums)
index=0
count=1
for i in range(lenth):
if nums[index]==nums[i]:
count+=1
else:
count-=1
if count==0:
index=i
count+=1
return nums[index]

最新文章

  1. 《Node即学即用》—— 读后总结
  2. 简单的oracle分页语句
  3. Takeown--夺取文件or文件夹所有权
  4. JAVA利用Zip4j解压缩【转】
  5. [转] Android开发者必备的42个链接
  6. js矩阵菜单或3D立体预览图片效果
  7. RT-Thread信号量实际运用—按键点灯
  8. emulator-arm.exe 已停止工作、 emulator-x86 已停止工作
  9. javascript 倒计时获取验证码
  10. 电信SDK Pay函数里面System.out.print 无输出消息
  11. UVa 1606 (极角排序) Amphiphilic Carbon Molecules
  12. js实现placeholder效果
  13. Objective-C 笔记 字符串操作
  14. DESTOON伪静态的设置/news/1.html格式
  15. EasyUI - 要引入的JS文件
  16. 从零一起学Spring Boot之LayIM项目长成记(六)单聊群聊的实现
  17. 算法与数据结构(八) AOV网的关键路径(Swift版)
  18. Ubuntu系统查看显卡型号和NVIDIA驱动版本
  19. Mr. Rito Post Office [Aizu-2200] [图论] [DP]
  20. win10如何获得管理员权限_百度经验

热门文章

  1. 【算法】【网络流24题】巨坑待填(成功TJ,有时间再填)
  2. windows内存映射文件
  3. SDUT 3930 线段树
  4. 解决华为手机用rem单位,内容超出屏幕宽度问题
  5. 数据存储之 SharedPreference 共享参数 (转)
  6. 查找一个String中存储的多个数据
  7. outer的使用
  8. Java应用调试利器——BTrace教程
  9. 【poj1222-又一道开关问题】高斯消元求解异或方程组
  10. elementui table 多选 获取id