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 }
  • 相关阅读:
    docker 安装镜像
    Vagrant+Oracle VM VirtualBox创建linux虚拟机(centos7)
    idea配置git,github , gitee
    idea连接数据库
    idea基本设置
    git基础命令
    mybatis中的where
    重学 Java 设计模式:实战桥接模式(多支付渠道「微信、支付宝」与多支付模式「刷脸、指纹」场景)
    HTTPS加密原理
    优惠券数据库设计
  • 原文地址:https://www.cnblogs.com/SilverNebula/p/5910221.html
Copyright © 2011-2022 走看看