|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 15533617457 于 2020-10-28 11:25 编辑
题目:
用一维数组存储学号和成绩,然后,按成绩排序输出。
输入格式
输入第一行包括一个整数N(1<=N<=100),代表学生的个数。
接下来的N行每行包括两个整数p和q,分别代表每个学生的学号和成绩。
输出
按照学生的成绩从小到大进行排序,并将排序后的学生信息打印出来。
如果学生的成绩相同,则按照学号的大小进行从小到大排序。
- #include<stdio.h>
- #include<stdlib.h>
- typedef struct
- {
- int id;
- double score;
- }student;
- int main(void)
- {
- //输入数据
- int n=0;
- printf("输入学生的人数");
- scanf("%d",&n);
- student *stu=NULL;
- stu=(student*)malloc(n*sizeof(student));
- for(int i=0;i<n;i++)
- {
- printf("输入学生的学号");
- scanf("%d",&(stu+i)->id);
- printf("输入学生的成绩");
- scanf("%d",&(stu+i)->score);
- }
- //交换
- int tempsc; //交换成绩的变量
- int tempid; //交换id的变量
- //交换循环
- for(int i=0;i<n;i++)
- {
- for(int j=i+1;j<n;j++)
- {
- if((stu+j)->score<(stu+i)->score)
- {
- tempsc=(stu+i)->score;
- (stu+i)->score=(stu+j)->score;
- (stu+j)->score=tempsc;
- tempid=(stu+i)->id;
- (stu+i)->id=(stu+j)->id;
- (stu+j)->id=tempid;
- }
- //当成绩相等的时候比较id大小
- else if((stu+j)->score==(stu+i)->score)
- {
- //交换id
- if((stu+j)->id<(stu+i)->id)
- {
- tempsc=(stu+i)->score;
- (stu+i)->score=(stu+j)->score;
- (stu+j)->score=tempsc;
- tempid=(stu+i)->id;
- (stu+i)->id=(stu+j)->id;
- (stu+j)->id=tempid;
- }
- }
- }
- }
- //输出数据
- for(int i=0;i<n;i++)
- {
- printf("%d:%d\n",(stu+i)->id,(stu+i)->score);
- }
- free(stu);
- return 0;
- }
复制代码
- #include<stdio.h>
- #include<stdlib.h>
- typedef struct
- {
- int id;
- //你的代码里用的int ,这里把 double 改成 int
- int score;
- }student;
- int main(void)
- {
- //输入数据
- int n=0;
- printf("输入学生的人数");
- scanf("%d",&n);
- student *stu=NULL;
- stu=(student*)malloc(n*sizeof(student));
- for(int i=0;i<n;i++)
- {
- printf("输入学生的学号");
- scanf("%d",&(stu+i)->id);
- printf("输入学生的成绩");
- scanf("%d",&(stu+i)->score);
- }
- //交换
- int tempsc; //交换成绩的变量
- int tempid; //交换id的变量
- //交换循环
- //前面的for循环里已经定义 i 了,这里不需要再定义了,把 int 去掉就可以了
- for(i=0;i<n;i++)
- {
- for(int j=i+1;j<n;j++)
- {
- if((stu+j)->score<(stu+i)->score)
- {
- tempsc=(stu+i)->score;
- (stu+i)->score=(stu+j)->score;
- (stu+j)->score=tempsc;
- tempid=(stu+i)->id;
- (stu+i)->id=(stu+j)->id;
- (stu+j)->id=tempid;
- }
- //当成绩相等的时候比较id大小
- else if((stu+j)->score==(stu+i)->score)
- {
- //交换id
- if((stu+j)->id<(stu+i)->id)
- {
- tempsc=(stu+i)->score;
- (stu+i)->score=(stu+j)->score;
- (stu+j)->score=tempsc;
- tempid=(stu+i)->id;
- (stu+i)->id=(stu+j)->id;
- (stu+j)->id=tempid;
- }
- }
- }
- }
- //输出数据
- //前面的for循环里已经定义 i 了,这里不需要再定义了,把 int 去掉就可以了
- for(i=0;i<n;i++)
- {
- printf("%d:%d\n",(stu+i)->id,(stu+i)->score);
- }
- free(stu);
- return 0;
- }
复制代码
|
|