C语言中使用系统自带的快排函数
题目
. 德才论 () 宋代史学家司马光在《资治通鉴》中有一段著名的“德才论”:“是故才德全尽谓之圣人,才德兼亡谓之愚人,德胜才谓之君子,才胜德谓之小人。凡取人之术,苟不得圣人,君子而与之,与其得小人,不若得愚人。” 现给出一批考生的德才分数,请根据司马光的理论给出录取排名。 输入格式: 输入第1行给出3个正整数,分别为:N(<=),即考生总数;L(>=),为录取最低分数线,即德分和才分均不低于L的考生才有资格被考虑录取;H(<),为优先录取线——德分和才分均不低于此线的被定义为“才德全尽”,此类考生按德才总分从高到低排序;才分不到但德分到线的一类考生属于“德胜才”,也按总分排序,但排在第一类考生之后;德才分均低于H,但是德分不低于才分的考生属于“才德兼亡”但尚有“德胜才”者,按总分排序,但排在第二类考生之后;其他达到最低线L的考生也按总分排序,但排在第三类考生之后。 随后N行,每行给出一位考生的信息,包括:准考证号、德分、才分,其中准考证号为8位整数,德才分为区间[, ]内的整数。数字间以空格分隔。 输出格式: 输出第1行首先给出达到最低分数线的考生人数M,随后M行,每行按照输入格式输出一位考生的信息,考生按输入中说明的规则从高到低排序。当某类考生中有多人总分相同时,按其德分降序排列;若德分也并列,则按准考证号的升序输出。
输入样例: 输出样例:
这里使用了多字段排序,调用系统自带的快速排序最为合适,需要实现自己的cmp函数。
#include <stdio.h>
#include <stdlib.h>
#include <malloc.h> typedef struct
{
int num;
int d;
int c;
}student; int comp(const void *a, const void *b)
{
//按照总分第减排序
if((*(student*)a).d+(*(student*)a).c != (*(student*)b).d+(*(student*)b).c)
return ((*(student*)b).d+(*(student*)b).c)-((*(student*)a).d+(*(student*)a).c);
//按照道德分第减排序
else if((*(student*)a).d != (*(student*)b).d)
return (*(student*)b).d-(*(student*)a).d;
//按照学好递增排序
else return (*(student*)a).num-(*(student*)b).num;
} int main()
{
int n,l,h,i,count=;
int num,d,c;
int n1=,n2=,n3=,n4=;
student *p1;
student *p2;
student *p3;
student *p4;
student temp;
scanf("%d %d %d",&n,&l,&h);
p1 = (student *)malloc(*sizeof(student));
p2 = (student *)malloc(*sizeof(student));
p3 = (student *)malloc(*sizeof(student));
p4 = (student *)malloc(*sizeof(student)); for(i=;i<n;i++)
{
scanf("%d %d %d",&temp.num,&temp.d,&temp.c);
if((temp.d>=l)&&(temp.c>=l))
{
if((temp.d>=h)&&(temp.c>=h))
p1[n1++] = temp;
else if(temp.d>=h)
p2[n2++] = temp;
else if(temp.d>=temp.c)
p3[n3++] = temp;
else p4[n4++] = temp;
}
} qsort(p1,n1,sizeof(student),comp);
qsort(p2,n2,sizeof(student),comp);
qsort(p3,n3,sizeof(student),comp);
qsort(p4,n4,sizeof(student),comp);
printf("%d\n",n1+n2+n3+n4);
for(i=;i<n1;i++)
printf("%d %d %d\n",p1[i].num,p1[i].d,p1[i].c);
for(i=;i<n2;i++)
printf("%d %d %d\n",p2[i].num,p2[i].d,p2[i].c);
for(i=;i<n3;i++)
printf("%d %d %d\n",p3[i].num,p3[i].d,p3[i].c);
for(i=;i<n4;i++)
printf("%d %d %d\n",p4[i].num,p4[i].d,p4[i].c);
return ;
}
C语言中使用系统自带的快排函数的更多相关文章
- iOS程序中调用系统自带应用(短信,邮件,浏览器,地图,appstore,拨打电话,iTunes,iBooks )
在网上找到了下在记录下来以后方便用 在程序中调用系统自带的应用,比如我进入程序的时候,希望直接调用safar来打开一个网页,下面是一个简单的使用:
- qsort 快排函数(C语言)
qsort 快排函数(C语言) 函数原型 void qsort(void *base, size_t nitems, size_t size, int (*compar)(const void *, ...
- C语言中的系统时间结构体类型
在C语言涉及中经常需要定时触发事件,涉及到获取系统时间,其结构体类型有多种.Unix/Linux系统下有以下几种时间结构: 1.time_t 类型:长整型,一般用来表示从1970-01-01 00:0 ...
- go语言中常用的文件和文件夹操作函数
package main; import ( "os" "log" "time" "fmt" ) //一些常用的文件操作 ...
- 五十五、SAP中调用系统自带的函数
一.我们需要取一个月中的最后一天,代码如下 二.执行结果如下 三.以上为纯手打,错了好几次才改过来,还有一个办法就是系统自动生成,点击编辑->模式 四.输入需要调用的函数名字BKK_GET_MO ...
- C语言中如何调用另一个源文件里的函数
在开发大型项目时,我们常常需要将一份源码分成多个源文件来进行编写,这样可以方便后期的维护.下面就介绍如何从一个源文件里调用另一个源文件的函数. 在源文件A1.c中调用A2.c 中的函数有两种方法: 1 ...
- C语言中的快速排序函数
C库中有自带的快排函数 qsort() ; 它的函数原型为: void qsort(void * , size_t ,size_t size , int (__cdecl *)(const void ...
- 如何在C语言中调用Swift函数
在Apple官方的<Using Swift with Cocoa and Objectgive-C>一书中详细地介绍了如何在Objective-C中使用Swift的类以及如何在Swift中 ...
- C语言中的自定义函数
C语言中可以使用系统函数也可以使用自己的函数,就是自定义函数 自定义函数分为四种 第一种:无参无返回值的 函数的声明 void sayH(); 函数的实现 void sayH(){ printf(&q ...
随机推荐
- C和指针 第十五章 习题
15.8 十六进制倾印码 #include <stdio.h> #include <stdlib.h> #include <string.h> #include & ...
- Dom元素的操作
getElementById(): 获取有指定惟一ID属性值文档中的元素 getElementsByName(name): 返回的是数组 getElementsByTagName(): 返回具有指定标 ...
- js的DOM的方法和属性总结
1.DOM的获取元素document.getElementById()context.getElementsByTagName(tag) (可以获取相应上下文环境所有的tag标签)context.ge ...
- 转:C++项目中的extern "C" {}
引言 在用C++的项目源码中,经常会不可避免的会看到下面的代码: #ifdef __cplusplus extern "C" { #endif /*...*/ #ifdef __c ...
- SDK,API,DLL名词解释
SDK (software devalopment kit) 软件开发工具包 : 一般都是一些软件工程师Wie特定的软件包.软件框架.硬件平台.操作系统等建立应用软件时的开发工具的集合. API (A ...
- 项目经理排期的几个tip
互联网敏捷开发的流程可以演绎出很多玩法,但最好都遵循以下几个tip: 1, 对项目经理最重要的一条是,通读所有需求文档,跟相关PM进行彻底沟通,把需求都搞熟搞透,防止漏排任务: 2, Stroy拆分要 ...
- Redis学习手册(主从复制)
一.Redis的Replication: 这里首先需要说明的是,在Redis中配置Master-Slave模式真是太简单了.相信在阅读完这篇Blog之后你也可以轻松做到.这里我们还是先列出一些理 ...
- js抛物线动画——加入购物车动效
参考文章:http://www.zhangxinxu.com/wordpress/2013/12/javascript-js-元素-抛物线-运动-动画/ parapola.js /*! * by zh ...
- cxf webservice 生成wsdl方法参数名称为arg0问题
在通过cxf生成webservice服务时,如果你是用ServerFactoryBean,那么在生成wsdl时,方法的参数名称会被自动命名为arg0,arg1...,如: <xsd:comple ...
- 一个简单的判断浏览器是否为IE9以下的方法
if(!-[1,]){ //是IE placeHolderIE9_(); }else{ //非IE if(navigator.userAgent.indexOf("MSIE 9.0" ...