学生信息插入


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

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

  1. 将student表中的数计学院的学生信息插入到stu表中。数据库批量插入

    将student表中的数计学院的学生信息插入到stu表中. 提示:请使用INSERT语句作答,stu数据表已存在,结构同student一样. 代码: insert into stu select * ...

  2. c语言学生信息结构体录入文件,C语言—学生信息管理系统

    学习了C语言结构体,链表和文件的知识之后,就可以做出一个学生信息管理系统了,下面的是我在刚学习完这块知识后写出来的,基本没什么界面,不过 能够实现  录入,添加,插入,遍历,删除,查询,并且保存到本地 ...

  3. 一个包含学生信息的顺序表

    #include <stdio.h> #include <stdlib.h> #include <string.h>#define MAXSIZE 100 /*单个 ...

  4. 【C语言结构体题】定义用于存储学生信息的结构体数组,输入学生的准考证号、姓名和成绩信息,计算总分,并按总分由高到低输出。

    在此基础上,增加下列功能函数 1.学生信息查询功能,根据学生的准考证号查询学生成绩信息 2.学生信息插入功能,在结构体数组的指定位置插入学生信息 3.学生信息删除功能,根据准考证号来删除满足条件的学生 ...

  5. C语言编写学生信息管理系统

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

  6. 你哪来这么多事(二):学生信息查找

    学生信息查找 Time Limit: 1 Sec  Memory Limit: 128 MB   64bit IO Format: %lld Description 某班 有n个学生(不超过100), ...

  7. python制作学生管理系统_Python——面向对象,简易学生信息管理系统

    一.概述 1.1涉及到的知识点 项目开发:创建项目,创建包,导入包: 面向对象:静态方法,继承,内置函数,自定义函数: 数据类型:列表,字典,字符串.列表.字典的转换和自动生成导向: 异常处理:捕获异 ...

  8. 【VB】学生信息管理系统5——数据库代码

    这次学生信息管理系统在代码的理解过程中遇到了一些问题.总结如下: 1. sql server的安装过程各个步骤的意思.在安装SQL Server的时候按照网上的步骤,我觉得这个需要学完整个数据库再返回 ...

  9. 【VB】学生信息管理系统4——数据库的发展

    由于连接数据的时候出现了很多不懂得问题,为什么要连接,它是怎么连接的,查着查着,就越看越多.又不舍得就这么放过这些问题,所以就耐心看看究竟是怎么回事! 1.自从出现数据库,人们渴望用数据和应用程序做交 ...

最新文章

  1. [译] JWT 与 Spring Cloud 微服务
  2. 用c#实现通讯中自定义发送序列化数据,可一定程度上实现可编程发送的功能
  3. 壁纸引擎java运行库_Microsoft Windows Desktop Runtime v5.0.0 桌面程序运行库(含常规运行库)...
  4. 使用FFmpeg命令行进行UDP、RTP推流(H264、TS),ffplay接收
  5. 轮播图js怎么设置图片自适应大小
  6. 使用Bootstrap插件datapicker获取时间
  7. Error dialog box generic entry point
  8. Linux下部署Tomcat项目笔记
  9. IntelliJ IDEA for Mac 封装字段(添加setter/getter方法)
  10. 一、mongodb数据库系列——介绍和安装 简单使用 增删改查
  11. python二叉树去重_python二叉树学习分享
  12. 计算机组成原理 试讲,常州信息职业技术学院-试讲ppt-计算机组成原理-信息表示.ppt...
  13. SQLSERVER之快速掌握T-SQL语句
  14. python内置函数__init__及__str__的区别
  15. 教孩子学编程 python 下载_教孩子学编程 python语言版
  16. 干线公路交叉口右转车辆与非机动车冲突精细化治理实例
  17. 工业可视化三维建模数据3d可视化平台
  18. 菜菜的sklearn机器学习实战——全部课件
  19. 【十一】消息中间件选型分析——从Kafka与RabbitMQ的对比来看全局
  20. 基础知识 | node js基础知识

热门文章

  1. 2022-2028年中国橡胶板的制造行业发展战略规划及投资方向研究报告
  2. RabbitMQ 入门系列(3)— 生产者消费者 Python 代码实现
  3. 【Spring】银行转账案例
  4. System.FormatException:“输入字符串的格式不正确。”
  5. Docker配置远程连接端口
  6. tensor和模型 保存与加载 PyTorch
  7. tryexceptelse可以嵌套
  8. BERT-Pytorch demo初探
  9. YOLOV4知识点分析(一)
  10. 2021年大数据Flink(一):乘风破浪的Flink-Flink概述