你哪来这么多事(一):学生信息插入
学生信息插入
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;
}
你哪来这么多事(一):学生信息插入相关推荐
- 将student表中的数计学院的学生信息插入到stu表中。数据库批量插入
将student表中的数计学院的学生信息插入到stu表中. 提示:请使用INSERT语句作答,stu数据表已存在,结构同student一样. 代码: insert into stu select * ...
- c语言学生信息结构体录入文件,C语言—学生信息管理系统
学习了C语言结构体,链表和文件的知识之后,就可以做出一个学生信息管理系统了,下面的是我在刚学习完这块知识后写出来的,基本没什么界面,不过 能够实现 录入,添加,插入,遍历,删除,查询,并且保存到本地 ...
- 一个包含学生信息的顺序表
#include <stdio.h> #include <stdlib.h> #include <string.h>#define MAXSIZE 100 /*单个 ...
- 【C语言结构体题】定义用于存储学生信息的结构体数组,输入学生的准考证号、姓名和成绩信息,计算总分,并按总分由高到低输出。
在此基础上,增加下列功能函数 1.学生信息查询功能,根据学生的准考证号查询学生成绩信息 2.学生信息插入功能,在结构体数组的指定位置插入学生信息 3.学生信息删除功能,根据准考证号来删除满足条件的学生 ...
- C语言编写学生信息管理系统
#include<stdio.h> #include<ctype.h> #include<stdlib.h> #include<string.h> #i ...
- 你哪来这么多事(二):学生信息查找
学生信息查找 Time Limit: 1 Sec Memory Limit: 128 MB 64bit IO Format: %lld Description 某班 有n个学生(不超过100), ...
- python制作学生管理系统_Python——面向对象,简易学生信息管理系统
一.概述 1.1涉及到的知识点 项目开发:创建项目,创建包,导入包: 面向对象:静态方法,继承,内置函数,自定义函数: 数据类型:列表,字典,字符串.列表.字典的转换和自动生成导向: 异常处理:捕获异 ...
- 【VB】学生信息管理系统5——数据库代码
这次学生信息管理系统在代码的理解过程中遇到了一些问题.总结如下: 1. sql server的安装过程各个步骤的意思.在安装SQL Server的时候按照网上的步骤,我觉得这个需要学完整个数据库再返回 ...
- 【VB】学生信息管理系统4——数据库的发展
由于连接数据的时候出现了很多不懂得问题,为什么要连接,它是怎么连接的,查着查着,就越看越多.又不舍得就这么放过这些问题,所以就耐心看看究竟是怎么回事! 1.自从出现数据库,人们渴望用数据和应用程序做交 ...
最新文章
- [译] JWT 与 Spring Cloud 微服务
- 用c#实现通讯中自定义发送序列化数据,可一定程度上实现可编程发送的功能
- 壁纸引擎java运行库_Microsoft Windows Desktop Runtime v5.0.0 桌面程序运行库(含常规运行库)...
- 使用FFmpeg命令行进行UDP、RTP推流(H264、TS),ffplay接收
- 轮播图js怎么设置图片自适应大小
- 使用Bootstrap插件datapicker获取时间
- Error dialog box generic entry point
- Linux下部署Tomcat项目笔记
- IntelliJ IDEA for Mac 封装字段(添加setter/getter方法)
- 一、mongodb数据库系列——介绍和安装 简单使用 增删改查
- python二叉树去重_python二叉树学习分享
- 计算机组成原理 试讲,常州信息职业技术学院-试讲ppt-计算机组成原理-信息表示.ppt...
- SQLSERVER之快速掌握T-SQL语句
- python内置函数__init__及__str__的区别
- 教孩子学编程 python 下载_教孩子学编程 python语言版
- 干线公路交叉口右转车辆与非机动车冲突精细化治理实例
- 工业可视化三维建模数据3d可视化平台
- 菜菜的sklearn机器学习实战——全部课件
- 【十一】消息中间件选型分析——从Kafka与RabbitMQ的对比来看全局
- 基础知识 | node js基础知识