码迷,mamicode.com
首页 > 其他好文 > 详细

luogu 1097

时间:2018-01-24 15:32:44      阅读:100      评论:0      收藏:0      [点我收藏+]

标签:sdi   algo   排序   cst   print   else   getchar   bsp   while   

排序一遍,保证数值相同的数放在一起。

直接枚举每一个数判断和前面的数是否相同:相同就累加数量;否则就输出,然后把数量重置为1。

#include"cstdio"
#include"cctype"
#include"algorithm"
using namespace std;
int read()
{
    int c,x=0; while(!isdigit(c=getchar()));
    while(x=x*10+c-0,isdigit(c=getchar()));
    return x;
}
int a[200001];
int main()
{
    int n=read();
    for(int i=1; i<=n; i++) a[i]=read();
    sort(a+1,a+n+1);
    int now=1,pre=a[1];
    for(int i=2; i<=n; i++)
        if(a[i]==pre) now++; else printf("%d %d\n",pre,now),pre=a[i],now=1;
    printf("%d %d\n",pre,now);
    return 0;
}

 

luogu 1097

标签:sdi   algo   排序   cst   print   else   getchar   bsp   while   

原文地址:https://www.cnblogs.com/TrassBlose/p/8341308.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!