欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 人文社科 > 生活经验 >内容正文

生活经验

你哪来这么多事(一):学生信息插入

发布时间:2023/11/27 生活经验 50 豆豆
生活随笔 收集整理的这篇文章主要介绍了 你哪来这么多事(一):学生信息插入 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

学生信息插入


Time Limit: 1 Sec  Memory Limit: 128 MB   64bit IO Format: %lld

Description

某班 有n个学生(不超过100),每个学生的信息包括学号(long no),姓名(char name[9])和成绩(int score)。

编写程序,先将n个学生的信息录入到结构体数组中(n个学生的数据已按成绩降序有序),

然后需要将m个学生的信息插入到该班中,使得插入后该数组仍然按成绩有序。

最后输出所有学生的信息。

注意:main函数已经给定(如下所示)。

           请将程序补充完整。

           提交时只需要提交自己补充的代码部分,不需要提交给定的main函数的代码部分。

#include<stdio.h>
int main()
{int i,n,m;struct student stu[100];while(scanf("%d",&n)!=EOF){input(stu,n);   //读入n个学生的数据scanf("%d",&m);for(i=0;i<m;i++){insert(stu,n);   //按照总分降序排序,如果总分相同的学号小的在前面n++;}print(stu,n);   //输出n个学生的信息}return 0;
}

 

Input

包含多组测试数据,每组测试数据第一行包含1个正整数n,表示已有学生人数。

接下来的n行,每行为1个学生的详细信息(已按成绩降序有序),包括学号,姓名和成绩,各数据之间用空格隔开。

接下来的一行包括一个正整数m,表示待插入的学生人数。

最后是m行,每行为1个待插入学生的信息,包括学号,姓名和成绩,各数据之间用空格隔开。

其中,n+m的值不超过100。

 

Output

每组测试数据输出占n+m行,每行输出一个学生的信息。每一行的输出数据依次为:学号,姓名,成绩。各部分数据之间用空格隔开。(具体详见样例输出)

 

Sample Input

3
1001 aaa 86
1002 bbb 78
1003 ccc 70
2
1004 ddd 50
1005 eee 99

 

Sample Output

1005 eee 99
1001 aaa 86
1002 bbb 78
1003 ccc 70
1004 ddd 50

题目分析:

插入的时候,一定要从后往前,把 stu[j+1] = stu[j] 才不会出问题,否则后面的会盖过前面的信息。。

实际上很简单,嘛。就像多米诺骨牌一样,一个搭在另一个上面,然后要找一个特定的位置插入。

以下仅为答案部分代码。

最后:抄代码是不对的哟~


struct student
{long no;char name[9];int score;
};
void input(struct student stu[100],int n)
{int i;for(i=1;i<=n;i++){scanf("%ld %s %d",&stu[i].no,stu[i].name,&stu[i].score);}return;
}
void insert(struct student stu[100],int n)
{int i,j,k,f;//为什么要考队列插入 啊 啊 啊struct student t;scanf("%ld %s %d",&t.no,t.name,&t.score);for(i=1;i<=n;i++){f=0;if(stu[i].score<t.score){for(j=n;j>=i;j--){stu[j+1]=stu[j];}stu[i]=t;f=1;break;}else if(stu[i].score==t.score){j=i;while(stu[j].score==t.score){if(stu[j].no>t.no){for(k=n;k>=j;k--){stu[k+1]=stu[k];}stu[j]=t;f=1;break;}j++;}if(f==0){for(k=n;k>=j;k--){stu[k+1]=stu[k];}stu[j]=t;f=1;}break;}if(f==0)stu[n+1]=t;}//抄作业是不对的哟!return;
}
void print(struct student stu[100],int n)
{int i;for(i=1;i<=n;i++){printf("%ld %s %d\n",stu[i].no,stu[i].name,stu[i].score);}return;
}

 

总结

以上是生活随笔为你收集整理的你哪来这么多事(一):学生信息插入的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。