#include <bits/stdc++.h>
using namespace std; int main(){
int n;
while(~scanf("%d",&n)){
int x,ans,cnt = 0;
while(n--){
scanf("%d",&x);
if(cnt == 0){
ans = x;
cnt++;
}else{
if(x == ans)
cnt++;
else
cnt--;
}
}
printf("%d\n",ans);
}
return 0;
}
/*

题目要求一个数至少出现(n+1)/2次。用cnt来记录解出现的次数,出现了正确解就令cnt自增1,不是正确解就使cnt自减1。

那么,正确解对应的cnt一定是不小于1的。可以用一个极端的例子来说明下:输入3 3 3 3 3 3 2 1 5 6 8,开始当ans=3时,cnt=6,

那么继续执行num!=3了,cnt开始自减,但最终cnt=1,始终不会进入程序if(cnt==0){}内部执行了。

利用最终的cnt,还可以计算出解出现的次数。*/

  

#include <iostream>
#include <stdlib.h>
using namespace std; int a[1000000]; int cmp(const void * x,const void* y)
{
return (*(int*)x - *(int*)y);
} int main()
{
int n,i,b,j,flag; while(cin >> n)
{
j = b = 0;
for(i = 0;i<n;i++)
{
cin >> a[i];
}
qsort(a,n,sizeof(int),cmp);
flag = a[0];
for(i = 0;i<n;i++)
{
if(a[i] == flag)
b++;
else if(a[i]!=flag)
{
if(b>=(n+1)/2)
{
break;
}
b = 0;
flag = a[i];
}
}
cout << flag << endl;
} return 0;
}

 

#include<stdio.h>
#include<string.h>
int map[500001];
int main()
{
int n,i,a,max;
while(scanf("%d",&n)!=EOF)
{
memset(map,0,sizeof(map));
for(i=0;i<n;i++)
{
scanf("%d",&a);
map[a]++;
if(map[a]>=(n+1)/2)
max=a;
}
printf("%d\n",max);
}
return 0;
}

  

#include <iostream>
#include <cstring>
using namespace std;
int a[1000001];
int main()
{
int x, n, i, num;
while(cin >> n)
{
memset(a, 0, sizeof(a));
for(i = 0; i < n; i++)
{
cin >> x;
a[x]++;
if(a[x] == (n+1)/2)//只要成立肯定是最大的了即保存再输出
num = x;
}
cout << num << endl;
}
return 0;
}

  

多元素即在数列中出现次数多于n/2的元素

我们很容易的看出来,在一个序列中如果去掉2个不同的元素,
那么原序列中的多元素,在新的序列中还是多元素,
因此我们只要按照序列依次扫描,先把t赋值给result,
增加个计数器,cnt = 1;然后向右扫描,
如果跟result相同,则cnt++,不同,那么cnt --,
这个真是我们从上面那个结论里得出的,一旦cnt == 0了,
那么必定c不是多元素,这个时候把t赋值为result,cnt = 1;,
重复该过程,知道结束,这个时候,result就是多元素,
这个的时间复杂度为n,该题本来可以用数组保存每个元素,
然后递归上述过程,可是,用数组超内存,
因此我们可以直接按照上述过程计算

最新文章

  1. ICommand相关知识
  2. VIM常用快捷键
  3. 【转】Paxos算法深入分析
  4. 关于ubuntu 系统
  5. C++程序设计实践指导1.8求指定范围内的所有素数改写要求实现
  6. sicily 1007 To and Fro (基地称号)
  7. C# 验证码生成(MVC和非MVC两种方式)
  8. 在linux环境下编译运行OpenCV程序的两种方法
  9. 企业级分布式存储应用与实战FastDFS实现
  10. Vue 爬坑之路(十一)—— 基于 Nuxt.js 实现服务端渲染(SSR)
  11. BZOJ 5467 Slay the Spire
  12. 通过Quartz 配置定时调度任务:使用cron表达式配置时间点
  13. 搭建SpringBoot+dubbo+zookeeper+maven框架(二)
  14. mybatis与hibernate区别与应用场景
  15. java多线程分块上传并支持断点续传最新修正完整版本[转]
  16. Python 3 学习笔记(1)
  17. 理解ValueStack的基本机制 OGNL表达式
  18. 个人项目:实现wc.exe(Java)
  19. Java精选笔记_集合【List(列表)接口】
  20. HttpUtility.UrlEncode与Server.UrlEncode()转码区别

热门文章

  1. IntellIJ IDEA 配置 Git,顺带解决Git Push rejected问题
  2. [Leetcode] Remove duplicates from sorted list 从已排序的链表中删除重复元素
  3. NEYC 2017 自动取款机 atm Day6 T1
  4. 【翻译】为什么Java中的String不可变
  5. 第116讲 boost::algorithm::string之替换和删除
  6. json获取属性值的方式
  7. fuser命令找到占用资源的进程
  8. 理解SetCapture、ReleaseCapture、GetCapture(控制了消息发往哪个窗口,是理解消息的关键)
  9. C++构造函数重载以及默认参数引起的二义性
  10. 栈与递归的实现(Hanoi塔问题等等)