PAT乙级1004

PAT乙级10041004.成绩排名(20)时间限制400ms内存限制65536kB代码长度限制8000B判题程序Standard作者CHEN,Yue读入n名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。输入格式:每个测试输入包含1个测试用例,格式为第1行:正整数n第2行:第1个学生的姓名学号成绩第3行:第2个学生的姓名学号成绩…………

大家好,又见面了,我是你们的朋友全栈君。

1004. 成绩排名 (20)

时间限制
400 ms

内存限制
65536 kB

代码长度限制
8000 B

判题程序
Standard

作者
CHEN, Yue

读入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

———————————以上为问题描述————————————————

#include <stdio.h>
#define maxsize 20 
#define maxsize1 101 

int main()
{

typedef struct arrange{
//学生结构 
char name[maxsize];
char number[maxsize];
int grade;
}arrange;

int n=0,i=0;
arrange a[maxsize1];
int low=0,high=0;
scanf(“%d”,&n); //输入学生数目 

for(i=0;i<n;++i){
//输入每个学生的姓名,学号,成绩 
scanf(“%s %s %d”,&a[i].name,&a[i].number,&a[i].grade);
}

for(i=0;i<n;++i){
//遍历学生数组,得出最高分和最低分的学生 
if(a[i].grade>a[high].grade){

high=i;
}
if(a[i].grade<a[low].grade){

low=i;
}
}
//输出最高分和最低分学生 
printf(“%s %s\n”,a[high].name,a[high].number);
printf(“%s %s\n”,a[low].name,a[low].number);

return 0;
 } 

————————————-以上为我的c语言代码—————————————–

经验教训

1.学习了结构体的构造

typedef struct arrange{

        语句A;

        语句B;

}arrange;

arrange a[maxsize];

=struct arrange{

        A;

        B;

};

struct arrange a[maxsize];

2注意数组长度。

这个题目不难,但是我做的时候第一次三组数据只对了一个,后发现原因,是maxsize太小了,题中说明不超过10,但是我输入的是字符串,所以最后一位被’\0’占据,所以我只能最多输入9个字符,对于10个字符的测试数据自然不通过。将10修改为11(后来为了保险我就直接修改成20)后通过两个测试数据,第三个显示段错误,网上搜索发现依旧是数组溢出问题将maxsize1改为110,再次测试就全对了。

3在一行中连续输入字符串,以空格隔开

一开始我的输入是这样的

scanf(“%s”,&a[i].name);

scanf(“%s”,&a[i].name);

scanf(“%s”,&a[i].name);

达不到在一行中输入的目的

后来改成这样就可以了

scanf(“%s %s %d”,&a[i].name,&a[i].number,&a[i].grade);

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136765.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月3日 上午7:00
下一篇 2022年6月3日 上午7:00


相关推荐

  • Redis

    Redis

    2021年3月12日
    163
  • exosip「建议收藏」

    exosip「建议收藏」exosip针对UA是对osip进行扩展,oSIP不提供不论什么高速产生请求消息和响应消息的方法,全部请求消息和响应消息的形成必须调用一组sipmessageapi来手动组装完毕,所以作者在osi

    2022年7月1日
    45
  • mysql中添加索引的命令_mysql添加索引命令

    mysql中添加索引的命令_mysql添加索引命令1 PRIMARYKEY 主键索引 mysql gt ALTERTABLE table name ADDPRIMARYKE column 2 UNIQUE 唯一索引 mysql gt ALTERTABLE table name ADDUNIQUE column 3 INDEX 普通索引 mysql gt ALTERTABLE

    2025年11月16日
    4
  • TCPDF_程序说明文档

    TCPDF_程序说明文档TCPDF说明文档一、首先调用TCPDF文件require_once(‘tcpdf.php’);二、实例化TCPDF类页面方向(P=肖像,L=景观)、测量(mm)、页面格式$pdf=newTCPDF(‘P’,’mm’,’A4′,true,’UTF-8′,false);三、设置文档信息设置文档信息—-文件创作者…

    2025年10月2日
    9
  • 动态规划经典题目_leetcode合并两个有序数组

    动态规划经典题目_leetcode合并两个有序数组一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “Finish” )。问总共有多少条不同的路径?示例 1:输入:m = 3, n = 7输出:28示例 2:输入:m = 3, n = 2输出:3解释:从左上角开始,总共有 3 条路径可以到达右下角。向右 -> 向下 -> 向下向下 -> 向下 -> 向右向下 -> 向右 -&gt

    2022年8月8日
    6
  • Kafka实战:如何把Kafka消息时延秒降10倍

    Kafka实战:如何把Kafka消息时延秒降10倍

    2022年4月2日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号