zoukankan      html  css  js  c++  java
  • TYVJ3680 找妹子

    时间: 1000ms / 空间: 1200KiB / Java类名: Main

    背景

    本题由 @fjzzq2002 提供,已奖励20金币。

    描述

    sps是zzq的好伙伴。

    sps一天叫来了许多个妹子。然后sps看了看这些妹子,说了m个数。这m个数中出现次数最多的数就是sps最喜欢的妹子的编号。因为sps非常专一,他最喜欢的妹子的编号出现的次数大于m的一半。

    你自然想知道一下sps最喜欢哪个妹子。

    m<=1000000。m个数均在int范围内的正数。

    注意看时空限制!

    输入格式

    第一行一个数m。

    第二行m个数。

    输出格式

    输出出现次数最多的数。

    备注

    空间1.2MB,连m个数都存不下。

    样例输入:

    8
    2 3 3 2 3 3 2 3

    样例输出:

    3

    题目钦定了答案值出现次数大于m/2

    在线处理,记当前答案ans,答案出现次数cnt,每次读入数x,如果x和ans相同,cnt++。不同,cnt–-。当cnt<0时,将ans更新为x。如果一个数出现次数大于m/2,它最终一定会被选为ans。

     1 /*by SilverN*/
     2 #include<algorithm>
     3 #include<iostream>
     4 #include<cstring>
     5 #include<cstdio>
     6 #include<cmath>
     7 using namespace std;
     8 int read(){
     9     int x=0,f=1;char ch=getchar();
    10     while(ch<'0' || ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    11     while(ch>='0' && ch<='9'){x=x*10+ch-'0';ch=getchar();}
    12     return x*f;
    13 }
    14 int x,cnt,m;
    15 int ans;
    16 int main(){
    17     m=read();
    18     int i,j;
    19     for(i=1;i<=m;i++){
    20         x=read();
    21         if(x==ans){
    22             cnt++;
    23             continue;
    24         }
    25         cnt--;
    26         if(cnt<0){
    27             ans=x;
    28             cnt=1;
    29         }
    30     }
    31     cout<<ans<<endl;
    32     return 0;
    33 }
  • 相关阅读:
    opencv和linux的关联
    附加数据库 对于server XXX失败
    android.app.Dialog(23)里window的那些事(坑)
    hdu 4722 Good Numbers(数位dp)
    Java程序猿必知的10个调试技巧
    iir调试记录
    在Scope利用Content sharing Widget来分享内容
    JavaEE 技术选型建议,server配置,部署策略
    x265探索与研究(四):怎样编码视频?
    计算git树上随意两点的近期切割点。
  • 原文地址:https://www.cnblogs.com/SilverNebula/p/5910221.html
Copyright © 2011-2022 走看看