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);

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • C++11新特性之右值引用(&&)、移动语义(move)、完美转换(forward)

    1.右值引用个人认为右值引用的目的主要是为了是减少内存拷贝,优化性能。比如下面的代码:str为临时对象,然后调用Stringd的拷贝构造函数,将临时对象的值赋值给String,这种拷贝是完全没

    2021年12月28日
  • 空间统计:Moran’s I(莫兰指数)

    空间统计:Moran’s I(莫兰指数)前两天聊了空间统计学里面的两个经典概念,今天来说说第一篇文章留下的大坑:Moran’sI。首先,Moran’sI这个东西,官方叫做:莫兰指数,是澳大利亚统计学家帕特里克·阿尔弗雷德·皮尔斯·莫兰(PatrickAlfredPierceMoran)(好长的名字,不过一般都简称为:帕克·莫兰,就是下图这位中年帅哥了),在1950年提出的。这一年,朝鲜战争爆发。莫兰同学1917…

  • 中国剩余定理解析_中国剩余定理详解

    中国剩余定理解析_中国剩余定理详解孙子问题最早,在《孙子算经》中有这样一个问题:“今有物不知其数,三三数之剩二,五五数之剩三,七七数之剩二,问物几何?用白话描述就是,现在有一个数不知道是多少,只知道这个数除以3余2,除以5余3,除以7余2,问这个数是多少?上面的问题可以转换为以下这样一个方程组:{xmod3=2xmod5=3xmod7=2\begin{cases}x\quadmod\quad3=2\\x\…

    2022年10月27日
  • strstr函数头文件_strstr函数[通俗易懂]

    strstr函数头文件_strstr函数[通俗易懂]函数名:strstr功能:在串中查找指定字符串的第一次出现用法:char*strstr(char*str1,char*str2);程序例:#include#includeintmain(void){char*str1=”BorlandInternational”,*str2=”nation”,*ptr;ptr=strstr(str1,str2);print…

  • Spring Boot – Mybatis 缓存

    Spring Boot – Mybatis 缓存mybatis提供查询缓存,用于减轻数据压力,提高数据库性能。mybaits提供一级缓存和二级缓存。一级缓存一级缓存是sqlSession级别的缓存。在操作数据库时需要构造sqlSession对象,在对象中有一个(内存区域)数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。一级缓存的作用域是同一个SqlSession,在同一个sqlSession中两次执行相同的sql语句,第一次执行完毕会将数据库中查询的数据写到缓存(内存

  • php vld_phpenv使用教程

    php vld_phpenv使用教程1、查看本地是否已经安装了vld扩展,如果没有任何输出,那就准备安装吧![root@taiwu~]#/home/work/lib/php5.6.7/bin/php-m|grepvld2、去官方网站下载vld(http://pecl.php.net/package/vld),找到最新版本,右键复制地址链接就能得到下载地址,通过浏览器直接下载也行。我是通过wget命令在centos的命…

    2022年10月30日

发表回复

您的电子邮箱地址不会被公开。

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