博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ 2456 mode
阅读量:5046 次
发布时间:2019-06-12

本文共 852 字,大约阅读时间需要 2 分钟。

       这道题我是受一位大神启发,写出的一个看起来没有一点道理,但他就是正确的解法,整体思路是这样的,由于我们需要求的是数量超过总数一半的数,因此我的想法是,用一个变量记录当前某个值出现的次数,每出现一次加一,反之减一,若变量为零,则把某个值替换为当前值,最后输出这个当前值即可。

       是不是很诡异,但他就是对的,让我来给你分析一下,我们要的结果必定大于总数一半,因此他出现的个数一定大于非他的个数,假设一组数据如下5,6,5,5,3,5,3,4,5,3,5,这里结果应为5,按思路来想没问题,那我们现在想办法卡死他,唯一有可能的方法就是最开始不是5,然后开始不断消耗5,当不得不更换数字时,不让他是5,则如下:3,3,5,3,5,5,6,5,4,5,5,好的这个方法失败了,那么换个思路,开始是5,快结束时换成不是5,则如下:5,5,5,5,5,6,4,3,3,3,5,依然失败了,由此可见,这个方法是正确的。

代码如下(简单!简单!再简单!):

#include
using namespace std;int n,a,tot,now;int main(){ scanf("%d",&n); while (n) { n--; scanf("%d",&a); if (now==a) tot++; else { tot--; if (tot<=0) { tot=1; now=a; } } } printf("%d",now); return 0;}
感谢各位的观看,希望能对各位有所帮助,谢谢。

转载于:https://www.cnblogs.com/szy-wlxy/p/4696677.html

你可能感兴趣的文章
2018.11.15 Nginx服务器的使用
查看>>
Kinect人机交互开发实践
查看>>
百度编辑器UEditor ASP.NET示例Demo 分类: ASP.NET...
查看>>
JAVA 技术类分享(二)
查看>>
android客户端向服务器发送请求中文乱码的问
查看>>
Symfony翻译教程已开课
查看>>
TensorFlow2.0矩阵与向量的加减乘
查看>>
NOIP 2010题解
查看>>
javascript中的each遍历
查看>>
String中各方法多数情况下返回新的String对象
查看>>
浅谈tcp粘包问题
查看>>
UVA11524构造系数数组+高斯消元解异或方程组
查看>>
排序系列之——冒泡排序、插入排序、选择排序
查看>>
爬虫基础
查看>>
jquery.lazyload延迟加载图片第一屏问题
查看>>
HDU 1011 Starship Troopers (树形DP)
查看>>
手把手教你写DI_1_DI框架有什么?
查看>>
.net常见的一些面试题
查看>>
OGRE 源码编译方法
查看>>
上周热点回顾(10.20-10.26)
查看>>