ALGO-141_蓝桥杯_算法训练_P1102
定义一个学生结构体类型student,包括4个字段,姓名、性别、年龄和成绩。然后在主函数中定义一个结构体数组(长度不超过1000),并输入每个元素的值,
程序使用冒泡排序法将学生按照成绩从小到大的顺序排序,然后输出排序的结果。
输入格式:第一行是一个整数N(N<),表示元素个数;接下来N行每行描述一个元素,姓名、性别都是长度不超过20的字符串,年龄和成绩都是整型。
输出格式:按成绩从小到大输出所有元素,若多个学生成绩相同则成绩相同的同学之间保留原来的输入顺序。
输入:
Alice female
Bob male
Miller male 输出:
Bob male
Miller male
Alice female
记:
题目给出了用冒泡排序实现,但是冒泡排序会破坏当成绩相同时学生的排序
故使用插入排序
AC代码:
#include <stdio.h>
#define MAX 1000 typedef struct student
{
char name[+];
char gender[+];
int age;
int score;
}student; int main(void)
{
int i,j;
int n;
student stu[MAX+];
student tmp; /*初始化*/
scanf("%d",&n);
for (i = ; i <= n ; i ++)
{
scanf("%s %s %d %d",&stu[i].name,&stu[i].gender,&stu[i].age,&stu[i].score);
} /*插入排序*/
for (i = ; i <= n ; i ++)
{
tmp = stu[i];
for (j = i ; j> && tmp.score < stu[j-].score ; j --)
{
stu[j] = stu[j-];
}
stu[j] = tmp;
} /*结果输出*/
for (i = ; i <= n ; i ++)
{
printf("%s %s %d %d\n",stu[i].name,stu[i].gender,stu[i].age,stu[i].score);
} return ;
}
ALGO-141_蓝桥杯_算法训练_P1102的更多相关文章
- ALGO-143_蓝桥杯_算法训练_字符串变换
		
问题描述 相信经过这个学期的编程训练,大家对于字符串的操作已经掌握的相当熟练了.今天,徐老师想测试一下大家对于字符串操作的掌握情况.徐老师自己定义了1,,,,5这5个参数分别指代不同的5种字符串操作, ...
 - ALGO-6_蓝桥杯_算法训练_安慰奶牛
		
记: 本题目考的是最小生成数,可使用Kruskal算法 第一次,20分 原因:使用动态数组,有概率报运行错误(大雾= =) 第二次,100分 原因:改用静态数组,一次过 示例代码: #include ...
 - ALGO-5_蓝桥杯_算法训练_最短路
		
记: 一开始没接触过关于最短距离的算法,便开始翻阅关于图的知识, 得知关于最短距离的算法有Dijkstra算法(堆优化暂未看懂),Bellman-Ford算法,Floyd算法,SPFA算法. 由于数据 ...
 - 蓝桥杯_算法训练_ALGO10_集合运算
		
这个题实际上思路是比较简单的,但是需要注意细节问题. 思路:读入数组之后进行排序,然后再求交.并.补集. 首先排序:(使用的是冒泡排序) #include<iostream> using ...
 - 蓝桥杯_算法训练_Torry的困惑(基本型)
		
这个题目就是求质数的乘积,在加一个模,思路比较简单,直接上代码: #include<iostream> using namespace std; bool isPrime(int a) { ...
 - 蓝桥杯_算法训练_区间k大数查询
		
问题描述 给定一个序列,每次询问序列中第l个数到第r个数中第K大的数是哪个. 输入格式 第一行包含一个数n,表示序列长度. 第二行包含n个正整数,表示给定的序列. 第三个包含一个正整数m,表示询问个数 ...
 - ALGO-43_蓝桥杯_算法训练_A+B Problem
		
问题描述 输入A,B. 输出A+B. 输入格式 输入包含两个整数A,B,用一个空格分隔. 输出格式 输出一个整数,表示A+B的值. 样例输入 样例输出 数据规模和约定 -,,,<=A,B< ...
 - ALGO-39_蓝桥杯_算法训练_数组排序去重
		
问题描述 输入10个整数组成的序列,要求对其进行升序排序,并去掉重复元素. 输入格式 10个整数. 输出格式 多行输出,每行一个元素. 样例输入 样例输出 解题思路: 若输入的数字存在数组中,剔除,否 ...
 - ALGO-115_蓝桥杯_算法训练_和为T(枚举)
		
问题描述 从一个大小为n的整数集中选取一些元素,使得它们的和等于给定的值T.每个元素限选一次,不能一个都不选. 输入格式 第一行一个正整数n,表示整数集内元素的个数. 第二行n个整数,用空格隔开. 第 ...
 
随机推荐
- [LeetCode&Python] Problem 628. Maximum Product of Three Numbers
			
Given an integer array, find three numbers whose product is maximum and output the maximum product. ...
 - 螺旋图  comet3  (comet)  不同轴的圆周运动图
			
matlab 绘图 螺旋图小实例 动态显示comet3函数(comet显示平面) t=[:]; x=*t*sin(pi/).*cos(*t); y=*t*sin(pi/).*sin(*t); z=* ...
 - Java异常处理的方法
			
1.异常概述在程序中,错误可能产生于程序员没有预料到的各种情况,或者是超出了程序员可控制范围的环境因素,如用户的坏数据.试图打开一个根本不存在的文件等.在Java中这种在程序运行是可能出现的一些错误称 ...
 - 读书笔记--More Effective C++--效率(总结)
			
PS: 本文只是总结,具体内容需要去查看More Effective C++--效率部分. 1. 80—20准则 大约 20%的代码使用了 80%的程序资源:大约 20%的代码耗用了大约 80%的运行 ...
 - KMP算法自我理解  和  模板
			
字符串 abcd abc abcd abc 匹配串 cdabcd 匹配串的 next 0 0 0 0 1 2: 开始匹配 abcd abc abcd abc cd abc d a,d 匹配失 ...
 - MATLAB中版本和日期函数
			
本博客中输出版本号和日期的子函数,今天才发现忘记上代码了,这里补上 function banner() %% --------------------------------------------- ...
 - hdu4424 Conquer a New Region 并查集/类似最小生成树
			
The wheel of the history rolling forward, our king conquered a new region in a distant continent.The ...
 - 直面Java 第004期。
			
什么是值传递,什么是引用传递.为什么说Java中只有值传递 对于初学者来说,要想把这个问题回答正确,是比较难的.在第二天整理答案的时候,我发现我竟然无法通过简单的语言把这个事情描述的很容易理解,遗憾的 ...
 - mac  终端光标在单词之间移动
			
https://ruby-china.org/topics/1241#reply16 you can use : option + b / f not ctrl + <- / ->
 - 扩大UIButton的选区
			
设计为了美观.button有时设计的太小,这么一来是好看了.可是button不好点中了.曾经有非常多解决方法,如用hitTest等方法. 都比較复杂.后来我发现一个简单的方法. 原理就是U ...