C++ 成绩排名
读入 n(>)名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。
输入格式:
每个测试输入包含 1 个测试用例,格式为
第 1 行:正整数 n
第 2 行:第 1 个学生的姓名 学号 成绩
第 3 行:第 2 个学生的姓名 学号 成绩
  ... ... ...
第 n+1 行:第 n 个学生的姓名 学号 成绩
其中姓名和学号均为不超过 10 个字符的字符串,成绩为 0 到 100 之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。
输出格式:
对每个测试用例输出 2 行,第 1 行是成绩最高学生的姓名和学号,第 2 行是成绩最低学生的姓名和学号,字符串间有 1 空格。
输入样例:
3
Joe Math990112 89
Mike CS991301 100
Mary EE990830 95
输出样例:
Mike CS991301
Joe Math990112
1 #include <iostream>
2 #include <vector>
3 #include <string>
4 #include <cstdlib>
5 #include <algorithm>
6
7
8 using namespace std;
9
10 struct Student
11 {
12 string name;
13 string id;
14 int score;
15 };
16 bool cmp(Student &s1,Student &s2)
17 {
18 return s1.score > s2.score;
19 }
20
21 int main()
22 {
23 int line;
24 string input;
25 cin >> line;
26 vector<Student> students;
27 for(int i = 0; i < line;++i)
28 { Student stu;
29 for(int j = 0; j < 3;++j)
30 {
31 cin >> input;
32 if(j == 0)
33 {
34 stu.name = input;
35 }else if(j == 1){
36 stu.id = input;
37 }else if(j == 2)
38 {
39 stu.score = atoi(input.c_str());
40 }
41 }
42 students.push_back(stu);
43 }
44 sort(students.begin(),students.end(),cmp);
45 cout << students[0].name << " " << students[0].id << endl
46 << students[line-1].name << " " << students[line-1].id << endl;
47
48
49 return 0;
50 }
一开始想用getline是一次性接收一行数据,但是觉得太麻烦了,况且每一个数据刚好都是以空格分隔开的,所以就直接用了cin。cin只能接收空格前的,例如:hello world 只能接收到hello。
这样就直接两个循环,外层循环行,内层循环每行的数据。
不过有一个地方比较棘手,我cin输入接收类型是string的,但是呢成绩是double,因此要用转换类型的函数,我查资料得到两个函数。
一个是我上文用的int atoi(const char *str)。这个函数是c函数,导入文件是#include<cstdlib>
另一个是stoi函数,定义:stoi(字符串,起始位置,n进制),将 n 进制的字符串转化为十进制,导入文件是#include<string>
当然是第二种更好,但是我的codeblocks总是报错,于是就用了上文的atoi,如果可编译的话第二种是首选。
C++ 成绩排名的更多相关文章
- mysql成绩排名
		
关于mysql成绩排名,网上大部分只是order by简单排序,忽略了成绩相同并列名次的问题. 定义了一个表score结构为:
 - PAT乙级  1004. 成绩排名 (20)
		
1004. 成绩排名 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入n名学生的姓名.学号.成绩,分 ...
 - PAT-乙级-1004. 成绩排名 (20)
		
1004. 成绩排名 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 读入n名学生的姓名.学号.成绩,分 ...
 - PHP中通过sqlsrv调用存储过程——成绩排名去除重复字段的数据行
		
培训考试项目中,需要实现考试成绩排名:排名参考项为分数(score降序).参加日期(attendtime升序).第几次参加考试(frequency升序):并且,每个用户只保留一条数据(pid). 考试 ...
 - 福州大学软件工程1916|W班 第6次作业成绩排名
		
作业链接 团队第三次-项目原型设计 评分细则 博客评分标准 在随笔开头,备注小组同学的学号.(1') 文字准确.样式清晰.图文并茂.字数在1000字左右.(10') 原型模型必须采用专用的原型模型设计 ...
 - 福州大学软件工程1916|W班 第3次作业成绩排名
		
作业链接 结对第二次-文献摘要热词统计及进阶需求 评分细则 本次作业由三部分组成(程序满分80,博客满分70,工程能力满分30) 程序评分标准 基础需求 共有7个测试用例,每个满分20分并按照一定的映 ...
 - 福州大学软件工程1816 | W班 第1次作业成绩排名
		
1.作业地址 第一次作业--准备篇 2.作业要求 (1)回想一下你初入大学时对计算机专业的畅想 当初你是如何做出选择计算机专业的决定的? 你认为过去两年中接触到的课程是否符合你对计算机专业的期待,为什 ...
 - 福州大学软件工程1816 | W班 第2次作业成绩排名
		
作业链接 词频统计基础功能 评分细则 本次个人项目分数由两部分组成(博客分满分40分+程序得分满分60分) 博客评分规则 在文章开头给出你们Fork仓库的Github项目地址.(1') 在开始实现程序 ...
 - 福州大学软件工程1816 | W班 第3次作业成绩排名
		
写在前面 汇总成绩排名链接 1.作业链接 第三次作业--原型设计(结对第一次) 2.评分准则 本次作业总分 25分,由以下部分组成: (1)在随笔开头请加上该博客链接,以方便阅读时查看作业需求,并备注 ...
 - 福州大学软件工程1816 | W班 第4次作业(团队展示)成绩排名
		
作业链接 评分细则 队员姓名与学号(标记组长),其中4-7人一组,特殊情况经老师允许后可以突破限制:(1分) 队名(体现项目内容,并要求有亮点与个性):(1分) 拟作的团队项目描述:一句话(中英文不限 ...
 
随机推荐
- mongoDB 的一般使用
			
理解 mongodb 也是nosql 的一种.他的数据存储类型是一种和json格式比较像的数据类型,可以看作就是json. mongodb 里的数据库都是一个单独的库.一般需要用的库都会设置自己的us ...
 - PTA 列车调度 (25分)
			
PTA 列车调度 (25分) [程序实现] #include<bits/stdc++.h> using namespace std; int main(){ int num,n; cin& ...
 - MySQL:互联网公司常用分库分表方案汇总!
			
一.数据库瓶颈 不管是IO瓶颈,还是CPU瓶颈,最终都会导致数据库的活跃连接数增加,进而逼近甚至达到数据库可承载活跃连接数的阈值.在业务Service来看就是,可用数据库连接少甚至无连接可用.接下来就 ...
 - python3  在webelement对象里面获取元素路径的方法
			
一. 在webelement对象里面使用查找Xpath 查找时,必须使用.指明当前节点 food = driver.find_element_by_id('food') eles = food.fin ...
 - java meil
			
import java.util.Date; import java.util.List; import java.util.Properties; import javax.activation.D ...
 - [noi1779]D
			
先离散,然后将黑的看成1,白的看成-1,对整个序列差分,所有区间建为$(l,r+1)$的无向边,并标上-1和1,每一个点的前缀和即为该点的值 考虑什么情况下能够使得所有点都是0:当且仅当每一个点的度数 ...
 - Ubuntu压缩和解压缩
			
1.常用的压缩格式 tar tar.bz2 tar.gz 2.gzip压缩 gzip xxx //压缩 gzip -d xxx.gz //解压缩 gzip对文件夹的压缩 gzip -r xxx //文 ...
 - Hardware assisted virtualization and data execution protection must be enabled in the BIOS. See https://docs.docker.com/docker-for-windows/troubleshoot/#virtualization
			
解决办法:先关闭 Hyper-V ,然后重新开启 Hyper-V 即可! 来自:https://zhuanlan.zhihu.com/p/51939654
 - Pulsar云原生分布式消息和流平台v2.8.0
			
Pulsar云原生分布式消息和流平台 **本人博客网站 **IT小神 www.itxiaoshen.com Pulsar官方网站 Apache Pulsar是一个云原生的分布式消息和流媒体平台,最初创 ...
 - 面渣逆袭:HashMap追魂二十三问
			
大家好,我是老三. HashMap作为我们熟悉的一种集合,可以说是面试必考题.简单的使用,再到原理.数据结构,还可以延伸到并发,可以说,就一个HashMap,能聊半个小时. 1.能说一下HashMap ...