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 }
  • 相关阅读:
    PasswordHasher 算法
    Java的环境变量配置
    CSS2+DIV的学习心得
    struts2利用token机制拦截用户重复提交
    电脑开机出现 error: no such partition grub rescue
    MySQL limit实际用法的详细解析
    win7将硬盘由ATA修改为AHCI的方法
    与SVN相关的程序的调试问题【转】
    【转】JSP提交表单
    LigerUI 快速开发UI框架 链接
  • 原文地址:https://www.cnblogs.com/SilverNebula/p/5910221.html
Copyright © 2011-2022 走看看