题目描述

摸鱼村要选村长了!

选村长的规则是村里每个人进行一次投票,票数大于人数一半的成为村长。

然鹅摸鱼村的人都比较懒,你能帮他们写一个程序来找出谁当选村长吗?

(每名村民的编号都是一个int范围内的整数)

输入

多行,每行一个数字(int范围内)

输出

输出出现次数超过总数一半的数字。(保证一定有解)

输入样例

1
1
12345678
2
1

输出样例

1

题目链接:https://buaacoding.cn/problem/1897/index

题目概要:多行数据(具体几行未知),从中选出超过半数的数据。(保证这个数据一定存在)

题目分析:

  • 本题由于数据未知,而且数据量很大,所以试图开十分大的数组来卡数据的方式不是出题人的本意,因此需要找到一种“巧妙”的算法来实现
  • 本题的重点在于找出超过半数的数据,请注意:不是出现次数最多的数据!当然,本题中出现次数最多的一定是超过半数的数据,但如果对别的题来说,只是要找到出现次数最多的数据,那么下面这种算法就无法实现了。
  • 正如上面所分析:出现超过半数的数据,意味着其他所有数据出现的次数加起来也不如他多!
  • 下面介绍两种非常巧妙的思路

思路一:

借助计算机中每个数的存储都是二进制的形式,int为32位整数,每位只有两种情况,即0或者1。因此,出现次数超过半数的数据对应的二进制位上的0和1一定是最多的。(可能说起来仍然不好表述,看到代码一定能懂)

#include<stdio.h>
int main()
{
int cnt[][] = {};
// int 32位数每位对应的数字
// cnt[i][0] 表示第i位为0; cnt[i][1] 表示第i位为1;
int a, ans = , i;
while(scanf("%d",&a)!=EOF){
for(i = ; i < ; i++)
if(&(a>>i))
cnt[i][]++;
else
cnt[i][]++;
}
for(i = ; i < ; i++)
// 判断超过半数的数据第i位的数字
if(cnt[i][] > cnt[i][])
ans|=(<<i);
printf("%d",ans);
return ;
}
#include<stdio.h>
int main(){
int cnt[][] = {};
int i, temp;
while(~scanf("%d", &temp)){
for(i = ; i < ; i++){
if(temp & )
cnt[i][]++;
else
cnt[i][]++;
temp = temp >> ;
}
}
int ans = ;
for(i = ; i >= ; i--)
if(cnt[i][] > cnt[i][])
ans = (ans << ) + ;
else
ans = ans << ;
printf("%d", ans);
return ;
}

其思路之精巧令人咋舌!

思路二:

最坏的情况就是出现次数最多的数据和其他数据都抵消了,最后仍能剩下它这组数据。

正常情况可能存在其他数据之间也相互抵消的情况,那么最后更是只剩下这组数据了。

#include<stdio.h>
int main() {
int cnt = , n, x;
while(~scanf("%d", &x)) {
if(cnt == )
// 全部抵消完成(回到最初的起点
n = x;
if(x == n) {
cnt++;
} else {
cnt--;
}
}
printf("%d", n);
return ;
}

其思路之精巧令人咋舌!

思路三:

朴素做法,虽然不是本题出题人本意,但利用数组保存数据也不失为一种思路。

(附:本学期做C语言助教,老师告诉我,将此题应用到实际生活中,宁肯多开空间,也不能丢失选票)

#include <stdio.h>
#include <stdlib.h> int a[]; int comp_int(const void *a, const void *b)
{
return *(int *)a-*(int *)b;
} int main()
{
int cnt = ;
while (scanf("%d", &a[cnt]) != EOF)
{
cnt++;
}
cnt--;
qsort(a+, cnt, sizeof(int), comp_int);
  // 排序,排序完成后中间的数据一定是出现次数过半的数据
printf("%d", a[cnt / ]);
return ;
}

菜鸡学C语言之摸鱼村村长的更多相关文章

  1. 菜鸡学C语言之真心话大冒险

    题目描述 Leslie非常喜欢真心话大冒险的游戏.这一次游戏的规则有些不同.每个人都有自己的真心话,一开始每个人也都只知道自己的真心话.每一轮每个人都告诉指定的一个人他所知道的所有真心话,那么Lesl ...

  2. 菜鸡学C语言之寻根溯源

    题目描述 Mogg最近翻了翻自己家的族谱,想康康祖先是谁.但是族谱因为年久失修太乱了,他现在只整理出来了一系列父子关系,你能帮他找一找直系亲属中辈分最大的一位吗?(即父亲的父亲的父亲……) 输入 第1 ...

  3. 我是先学C语言还是先学C++,实不相瞒,鱼和熊掌可兼得!

    这是最近一周时间几个读者小伙伴所提的问题,我顺手截了两个图. 实不相瞒,这类问题之前也经常看到.     每次遇到这种问题,看起来很简单,但是打字一时半会还真说不清,想想今天周末了,写一篇文章来统一聊 ...

  4. 菜鸡谈OO 第二单元总结

    “欢迎来到(玄学)多线程的新世界” Homework1 单部傻瓜电梯调度 Part1 多线程设计策略 第一次学到了线程这个概念,与之前的编程体验大有不同.最大的区别在于从原本的线性发生程序变成了多个行 ...

  5. 菜鸡谈OO 第一单元总结

    “OOP永远是我的好朋友爸爸!” ——来自某无能狂怒的菜鸡 身处在OO的第一个摸鱼黄金周中的我,感觉到了巨大的满足感.如果写博客这种充满意义的事情可以代替我们亲爱的作业,那么我提议每周来两个:)下面开 ...

  6. ACM菜鸡退役帖——ACM究竟给了我什么?

    这个ACM退役帖,诸多原因(一言难尽...),终于决定在我大三下学期开始的时候写出来.下面说两个重要的原因. 其一是觉得菜鸡的ACM之旅没人会看的,但是新学期开始了,总结一下,只为了更好的出发吧. 其 ...

  7. HDU 2064 菜鸡第一次写博客

    果然集训就是学长学姐天天传授水铜的动态规划和搜索,今天讲DP由于困意加上面瘫学长"听不懂就是你不行"的呵呵传授,全程梦游.最后面对连入门都算不上的几道动态规划,我的内心一片宁静,甚 ...

  8. 一个数学不好的菜鸡的快速沃尔什变换(FWT)学习笔记

    一个数学不好的菜鸡的快速沃尔什变换(FWT)学习笔记 曾经某个下午我以为我会了FWT,结果现在一丁点也想不起来了--看来"学"完新东西不经常做题不写博客,就白学了 = = 我没啥智 ...

  9. HNOI2018 摸鱼记

    HNOI2018 摸鱼记 今天我又来记流水账啦 Day 0 颓废的一天. 我,球爷和杜教在颓膜膜.io ych看起来在搓碧蓝 鬼知道哥达鸭干了什么 学习氛围只局限在机房的一角 后来全体Oier开会,5 ...

随机推荐

  1. 线段树 HDU-1754 I Hate It

    附上原题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1754 Problem Description 很多学校流行一种比较的习惯.老师们很喜欢询问,从某某 ...

  2. jdk5升8问题记录-Spring2升4

    Spring2.x升4.x Hibernate3.x升5.0 jdbcOperations.queryForInt 替换为 queryForObject(sql, parameters, Intege ...

  3. Wireshark使用介绍(一):Wireshark基本用法

    抓取报文: 下载和安装好Wireshark之后,启动Wireshark并且在接口列表中选择接口名,然后开始在此接口上抓包.例如,如果想要在无线网络上抓取流量,点击无线接口.点击Capture Opti ...

  4. 堆叠式降噪自动编码器(SDA)

    1.1 自动编码器  自动编码器(AutoEncoder,AE)就是一种尽可能复现输入信号的神经网络,其输出向量与输入向量同维,常按照输入向量的某种形式,通过隐层学习一个数据的表示或对原始数据进行有效 ...

  5. RDLC报表数据集的一个细节,导致错误为 尚未数据源提供数据源实例

    报表中,数据集的名字DataSet_CZ, 这里报表这样加载,视乎是的. reportViewer1.LocalReport.DataSources.Add(new Microsoft.Reporti ...

  6. CCF CSP 201609-2 火车购票

    题目链接:http://118.190.20.162/view.page?gpid=T46 问题描述 请实现一个铁路购票系统的简单座位分配算法,来处理一节车厢的座位分配. 假设一节车厢有20排.每一排 ...

  7. Django的安装和一些操作

    1.安装 (1) 命令行: pip install django==1.11.18 pip install django==1.11.18 -i 源 (2) pycharm setting —> ...

  8. java消息服务学习之JMS高级特性

    将介绍的内容是: 控制消息确认.为发送消息指定选项.创建临时目的地.使用JMS本地事务.异步发送消息 五个方面. 1.控制消息确认 在JMS消息得到确认之前,并不认为它已经成功使用.要成功使用消息,通 ...

  9. Charles 抓包工具(新猿旺学习总结)

    Charles 抓包工具安装机操作 1.Charles 抓包工具是代理服务器工具,可以拦截数据,进行更改,返回数据,以实现前端后台的请求和响应数据的测试2.Charles 菜单介绍 Charles抓包 ...

  10. appium+夜神+python3 环境配置

    先感慨一下真的心累啊,踩了好多坑,断断续续四天终于把环境彻底搭建完了,由于之前看的网上的帖子都不是很全而且还带坑,决定自己写一篇综述,作为笔记. 一,首先是安装需要的环境: 需要用到的软件: 1. j ...