zoukankan      html  css  js  c++  java
  • [NOIP2007] 提高组 洛谷P1097 统计数字

    题目描述

    某次科研调查时得到了n个自然数,每个数均不超过1500000000(1.5*10^9)。已知不相同的数不超过10000个,现在需要统计这些自然数各自出现的次数,并按照自然数从小到大的顺序输出统计结果。

    输入输出格式

    输入格式:

    输入文件count.in包含n+1行;

    第一行是整数n,表示自然数的个数;

    第2~n+1每行一个自然数。

    输出格式:

    输出文件count.out包含m行(m为n个自然数中不相同数的个数),按照自然数从小到大的顺序输出。每行输出两个整数,分别是自然数和该数出现的次数,其间用一个空格隔开。

    输入输出样例

    输入样例#1:
    8
    2
    4
    2
    4
    5
    100
    2
    100
    
    
    输出样例#1:
    2 3
    4 2
    5 1
    100 2
    

    说明

    40%的数据满足:1<=n<=1000

    80%的数据满足:1<=n<=50000

    100%的数据满足:1<=n<=200000,每个数均不超过1500 000 000(1.5*109)

    NOIP 2007 提高第一题

    排序之后扫描一遍,记录连续出现的数的次数即可

     1 /*by SilverN*/
     2 #include<algorithm>
     3 #include<iostream>
     4 #include<cstring>
     5 #include<cstdio>
     6 #include<cmath>
     7 using namespace std;
     8 const int mxn=200010;
     9 int read(){
    10     int x=0,f=1;char ch=getchar();
    11     while(ch<'0' || ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    12     while(ch>='0' && ch<='9'){x=x*10+ch-'0';ch=getchar();}
    13     return x*f;
    14 }
    15 int n;
    16 int a[mxn];
    17 int main(){
    18     n=read();
    19     int cnt=0;
    20     for(int i=1;i<=n;++i){
    21         a[i]=read();
    22     }
    23     sort(a+1,a+n+1);
    24     int tmp=1;
    25     for(int i=2;i<=n+1;++i){
    26         if(a[i]==a[i-1])tmp++;
    27         else printf("%d %d
    ",a[i-1],tmp),tmp=1;
    28     }
    29     return 0;
    30 }
  • 相关阅读:
    2017ccpc全国邀请赛(湖南湘潭) E. Partial Sum
    Codeforces Round #412 C. Success Rate (rated, Div. 2, base on VK Cup 2017 Round 3)
    2017 中国大学生程序设计竞赛 女生专场 Building Shops (hdu6024)
    51nod 1084 矩阵取数问题 V2
    Power收集
    红色的幻想乡
    Koishi Loves Segments
    Wood Processing
    整数对
    Room and Moor
  • 原文地址:https://www.cnblogs.com/SilverNebula/p/6016458.html
Copyright © 2011-2022 走看看