229. Majority Element II My Submissions Question
Total Accepted: 23103 Total Submissions: 91679 Difficulty: Medium
Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. The algorithm should run in linear time and in O(1) space.
Hint:
How many majority elements could it possibly have?
Do you have a better hint? Suggest it!
最多只有两个候选数字。要求O(1)空间,可以分别用两个变量保存候选数字和计数,方法大致和169. Majority Element My Submissions Question相同。代码如下:
vector<int> majorityElement(vector<int>& nums) {
    vector<int> res;
    if (nums.empty())
        return res;
    int cand1 = nums[0], cand2 = 0;
    int count1 = 1, count2 = 0;
    for (int i = 1; i < nums.size(); ++i) {
        if (cand1 == nums[i]) {
            ++count1;
        }
        else if (cand2 == nums[i]) {
            ++count2;
        }
        else if (count1 == 0) {
            cand1 = nums[i];
            ++count1;
        }
        else if (count2 == 0) {
            cand2 = nums[i];
            ++count2;
        }
        else {
            --count1;
            --count2;
        }
    }
    //判断候选是否满足条件
    count1 = count2 = 0;
    for (int i = 0; i < nums.size(); ++i) {
        if (cand1 == nums[i])
            ++count1;
        else if (cand2 == nums[i])
            ++count2;
    }
    if (count1 > nums.size() / 3)
        res.push_back(cand1);
    if (count2 > nums.size() / 3)
        res.push_back(cand2);
    return res;
}229. Majority Element II My Submissions Question的更多相关文章
- leetcode 169. Majority Element 、229. Majority Element II
		169. Majority Element 求超过数组个数一半的数 可以使用hash解决,时间复杂度为O(n),但空间复杂度也为O(n) class Solution { public: int ma ... 
- 【刷题-LeetCode】229. Majority Element II
		Majority Element II Given an integer array of size n, find all elements that appear more than ⌊ n/3 ... 
- 【LeetCode】229. Majority Element II
		Majority Element II Given an integer array of size n, find all elements that appear more than ⌊ n/3 ... 
- 229. Majority Element II -- 找出数组中出现次数超过 ⌊ n/3 ⌋ 次的数
		Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. The algorit ... 
- LeetCode OJ 229. Majority Element II
		Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. The algorit ... 
- [LeetCode] 229. Majority Element II  多数元素 II
		Given an integer array of size n, find all elements that appear more than ⌊ n/3 ⌋ times. Note: The a ... 
- 【LeetCode】229. Majority Element II 解题报告(Python & C++)
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 hashmap统计次数 摩尔投票法 Moore Vo ... 
- leetcode 229 Majority Element II
		这题用到的基本算法是Boyer–Moore majority vote algorithm wiki里有示例代码 1 import java.util.*; 2 public class Majori ... 
- leetcode 229. Majority Element II(多数投票算法)
		就是简单的应用多数投票算法(Boyer–Moore majority vote algorithm),参见这道题的题解. class Solution { public: vector<int& ... 
随机推荐
- DATE_FORMAT() 函数
			DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据DATE_FORMAT(now(),'%Y-%m-%d %T') 
- 445port入侵具体解释
			445port入侵具体解释 关于"445port入侵"的内容445port入侵具体解释本站搜索很多其它关于"445port入侵"的内容 445port入侵, ... 
- 【PAT Advanced Level】1008. Elevator (20)
			没什么难的,简单模拟题 #include <iostream> using namespace std; int main() { int num; cin>>num; int ... 
- cocos2d-x 3.0环境搭建
			原文来自于:http://blog.csdn.net/linzhengqun/article/details/21663341 安装工具 1. 配置JDK JDK下载地址:http://www.ora ... 
- 第一周:读取XML深度数据并将其重建为三维点云
			本周主要任务:学习PCL点云库,掌握利用PCL对点云处理的方法 任务时间:2014年9月1日-2014年9月7日 任务完成情况:完成了读取单幅xml深度数据,并重建三维点云并显示 任务涉及基本方法: ... 
- 使用Java高速实现进度条
			基于有人问到如何做进度条,以下给个简单的做法: 主要是使用JProgressBar(Swing内置javax.swing.JProgressBar)和SwingWorker(Swing内置javax. ... 
- win7重新安装win7
			本方法适用于原本Win7系统下安装,无需U盘,非Ghost,简单几步操作之后与光盘安装过程一样,简便易操作,愿与和我一样有“洁癖”的朋友分享. 1.下载Win7原版光盘镜像,附下载地址: Win7旗舰 ... 
- int a[5]={}, &a+1与(int*)a+1的区别
			#include <iostream> #include <typeinfo> using namespace std; int main() { int b, *pb; ch ... 
- qsort函数、sort函数 (精心整理篇)
			先说明一下qsort和sort,只能对连续内存的数据进行排序,像链表这样的结构是无法排序的. 首先说一下, qsort qsort(基本快速排序的方法,每次把数组分成两部分和中间的一个划分值,而对于有 ... 
- php上传常见文件类型对应的$_FILES["file"]["type"](转)
			php上传常见文件类型对应的$_FILES["file"]["type"] from:http://hi.baidu.com/7book/item/374971 ... 
