83 学生信息

83 学生信息

作者: 孙辞海时间限制: 2S章节: 结构体

问题描述 :

你的程序需要从标准输入设备(通常为键盘)中输入N(1≤N≤10)个学生的信息,每项信息包含该学生的编号、姓名、性别、年龄、成绩共五项,按成绩进行排序,然后按成绩从低到高输出,输入保证没有相同的成绩。

输入说明 :

首先输入一个N(1≤N≤10),代表有几条学生记录,接下来N行每行包含一条学生记录,按照编号、姓名、性别、年龄、成绩的顺序给出,数据项之间以空格分隔,除了这五项之间的4个空格外,无其他空格。所有数据前后没有多余的空行,两个学生的记录之间也没有多余的空行。

输出说明 :

你的程序需要对学生的成绩按升序排序后输出所有学生的信息,每行一个学生的信息,同一个学生的信息之间以一个空格分隔。所有数据前后没有多余的空行,在行首和行尾没有多余的空格。

输入范例 :

2
1 aa male 13 1
2 bb female 14 0

输出范例 :

2 bb female 14 0
1 aa male 13 1

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

typedef struct Student
{
	int num;
	char name[20];
	char gender[10];
	int age;
	int grade;
}Student;

int main()
{
	int n;
	Student *stu;
	Student temp;
	scanf("%d",&n);
	stu=(Student *)malloc(sizeof(Student)*n);
	for(int i=0;i<n;i++)
	{
		scanf("%d %s %s %d %d",&stu[i].num,stu[i].name,stu[i].gender,&stu[i].age,&stu[i].grade);
	}
	for(int j=0;j<n-1;j++)
	{
		for(int k=j+1;k<n;k++)
			if(stu[j].grade>stu[k].grade)
			{
				temp=stu[j];
				stu[j]=stu[k];
				stu[k]=temp;
			}
	}
	for(int m=0;m<n;m++)
	{
		if(m==0)
			printf("%d %s %s %d %d",stu[m].num,stu[m].name,stu[m].gender,stu[m].age,stu[m].grade);
		else
			printf("\n%d %s %s %d %d",stu[m].num,stu[m].name,stu[m].gender,stu[m].age,stu[m].grade);
	}
}

猜你喜欢

转载自blog.csdn.net/HurryBen/article/details/105720263
83
今日推荐