ZCMU—1602
来源:互联网 发布:firefox debug js 编辑:程序博客网 时间:2024/05/18 00:14
1602: 卡斯丁狗的体测
Time Limit: 1 Sec Memory Limit: 128 MB[Submit][Status][Web Board]
Description
卡斯丁狗,在班长的号召下,去体育部查看了体侧成绩,尼玛,卡斯丁狗不想吐槽…然而他发现自己的分数居然才60分,“这不科学!”,卡斯丁狗心中暗想一定有问题,于是他仔细的查看每一门的分数,突然,他发现,明明自己的IBM是有18分的迷人的身材的得分,但是体重指数得分为0,这不是在逗我吗,卡斯丁狗叫到,生气的卡斯丁狗,心里想到这个明显的错误让我找半天,就不能有个排序吗?于是卡斯丁狗让你们重新整理这些数据。
Input
一个整数n(n<=100000),表示的是待整理的数据数量,接下来n行的数据
每行四个数据 Num表示序号,name,表示名字,kind表示类型,score表示这个类型的得分。{ 所有的字符串长度小于20位 }。
Output
先输出 类型,然后在输出这个类型下的所有人的成绩,要求类型按照字典序,同一类型下,先按照学号由小到大《如果某个人有多条记录的话,保存最大分数的那个记录》,具体看样例输出。注意:每一类型下的数据要和该数据所在的类型的后面的冒号对齐。
Sample Input
【分析】
看对sort的理解程度的一道题...讲真也看不出啥其实就是看你到底懂不懂cmp怎么影响sort排序的..
return 0交换return 1不交换...反正我是这样理解的,基于快速排序判断交换的时候的条件...嗯...每个人理解都不同~无所谓了
只要细节处理一下就可以了...string可以直接比较字典序,当然编号和分数不能用string 因为“3”>“25”
【代码】
#include <iostream>#include <cstdio>#include <cstring>#include <algorithm>using namespace std;struct xx{string id,name,ID;int s;}a[101000];int cmp(xx x,xx y){if (x.ID!=y.ID) return x.ID<y.ID;if (x.id!=y.id) return x.id<y.id;return x.s>y.s;}int main(){int n;while (~scanf("%d",&n)){for (int i=0;i<n;i++) cin>>a[i].id>>a[i].name>>a[i].ID>>a[i].s;sort(a,a+n,cmp);for (int i=0;i<n;i++)if (!i ||a[i].ID!=a[i-1].ID || a[i].id!=a[i-1].id){if (!i ||a[i].ID!=a[i-1].ID) cout<<a[i].ID<<":"<<endl;for (int j=0;j<a[i].ID.length();j++) cout<<" ";cout<<a[i].id<<" "<<a[i].name<<" "<<a[i].s<<endl;}}}
0 0
- ZCMU—1602
- ZCMU—1678
- ZCMU—1605
- ZCMU—1067
- ZCMU—1607
- ZCMU—1069
- ZCMU—1611
- ZCMU—1606
- ZCMU—1774
- ZCMU—1766
- ZCMU—1752
- ZCMU—1724
- ZCMU—1623
- ZCMU—1689
- ZCMU—1667
- ZCMU—1639
- ZCMU—1668
- ZCMU—1540
- centos下安装VirtualBox
- react native AsyncStorage 使用实例 异步存储数据以及读取
- shiro初识
- Android sqlite no such table异常
- Mysql5.7修改root密码教程
- ZCMU—1602
- 引用计数
- 开通博客 以后尽量坚持写下去!!!!!
- python类xlsxwriter导表
- 常用的linux命令及实例
- yum 中文语言包
- 23种设计模式(6):模版方法模式
- KMP 【bzoj3942】 Censoring
- 使用startService方式启动Service