题目

. 德才论 ()

宋代史学家司马光在《资治通鉴》中有一段著名的“德才论”:“是故才德全尽谓之圣人,才德兼亡谓之愚人,德胜才谓之君子,才胜德谓之小人。凡取人之术,苟不得圣人,君子而与之,与其得小人,不若得愚人。”

现给出一批考生的德才分数,请根据司马光的理论给出录取排名。

输入格式:

输入第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语言中使用系统自带的快排函数的更多相关文章

  1. iOS程序中调用系统自带应用(短信,邮件,浏览器,地图,appstore,拨打电话,iTunes,iBooks )

    在网上找到了下在记录下来以后方便用 在程序中调用系统自带的应用,比如我进入程序的时候,希望直接调用safar来打开一个网页,下面是一个简单的使用:

  2. qsort 快排函数(C语言)

    qsort 快排函数(C语言) 函数原型 void qsort(void *base, size_t nitems, size_t size, int (*compar)(const void *, ...

  3. C语言中的系统时间结构体类型

    在C语言涉及中经常需要定时触发事件,涉及到获取系统时间,其结构体类型有多种.Unix/Linux系统下有以下几种时间结构: 1.time_t 类型:长整型,一般用来表示从1970-01-01 00:0 ...

  4. go语言中常用的文件和文件夹操作函数

    package main; import ( "os" "log" "time" "fmt" ) //一些常用的文件操作 ...

  5. 五十五、SAP中调用系统自带的函数

    一.我们需要取一个月中的最后一天,代码如下 二.执行结果如下 三.以上为纯手打,错了好几次才改过来,还有一个办法就是系统自动生成,点击编辑->模式 四.输入需要调用的函数名字BKK_GET_MO ...

  6. C语言中如何调用另一个源文件里的函数

    在开发大型项目时,我们常常需要将一份源码分成多个源文件来进行编写,这样可以方便后期的维护.下面就介绍如何从一个源文件里调用另一个源文件的函数. 在源文件A1.c中调用A2.c 中的函数有两种方法: 1 ...

  7. C语言中的快速排序函数

    C库中有自带的快排函数 qsort() ; 它的函数原型为: void qsort(void * , size_t ,size_t size , int (__cdecl *)(const  void ...

  8. 如何在C语言中调用Swift函数

    在Apple官方的<Using Swift with Cocoa and Objectgive-C>一书中详细地介绍了如何在Objective-C中使用Swift的类以及如何在Swift中 ...

  9. C语言中的自定义函数

    C语言中可以使用系统函数也可以使用自己的函数,就是自定义函数 自定义函数分为四种 第一种:无参无返回值的 函数的声明 void sayH(); 函数的实现 void sayH(){ printf(&q ...

随机推荐

  1. 博客整理——Alpha版冲刺

    Alpha冲刺 助教链接:2016福州大学软件工程第五.六次团队作业-Alpha阶段成绩汇总 1.Transcend Daily Scrum Meeting --FirstDay Daily Scru ...

  2. React Native踩坑Tip

    最近在使用React Native(以下简称RN)中踩了个坑,RN只能异步调用原生方法,所以在原生方法直接调用UI刷新操作需要将任务递交到主线程才可以. RCT_EXPORT_METHOD(finis ...

  3. linux 复 带进度条

    rsync命令 #rsync -av --progress /mnt/yidong2/full20100526.tar.gz /mnt/yidong1/ 可以实现本机带进度条提示拷贝,可以实现不同机器 ...

  4. Linux安装ftp组件过程

    1   安装vsftpd组件 安装完后,有/etc/vsftpd/vsftpd.conf 文件,是vsftp的配置文件. [root@bogon ~]# yum -y install vsftpd 2 ...

  5. css3 FlexBox 弹性布局

    Flex 弹性布局 这个是css3中新添加的内容,现在已经支持所有的浏览器,利用Flex布局,可以简便.完整.响应式地实现各种页面布局. 注意:在设置 flex 后,子元素的flaot ,clear, ...

  6. JavaScript学习笔记(1))——————call,apply方法

    学习前端也有一段时间了,但是效果甚微.利用时间不够充分,虽然是利用工作之余来学习.但是这不能成为我的借口. 今天学习了(其实看了很多遍)call apply方法. function abc(a,b){ ...

  7. mkdir命令

    [mkdir]   创建目录     mkdir ===make directory 命令格式: mkdir [OPTION]... DIRECTORY 命令功能: 通过 mkdir 命令可以实现在指 ...

  8. 搭建Nginx+Java环境测试并且运行

    一.简介: Tomcat在高并发环境下处理动态请求时性能很低,而在处理静态页面更加脆弱.虽然Tomcat的最新版本支持epoll,但是通过Nginx来处理静态页面要比通过Tomcat处理在性能方面好很 ...

  9. tp框架实现ajax

    不墨迹,直接进主题. tp框架实现ajax 首先,我们先做一个testajax.html用来显示页面(只是一个简单的下拉列表^_^) <!DOCTYPE html PUBLIC "-/ ...

  10. QQ聊天界面模式切换

    1.打开一个聊天窗口 2.按照图上步骤 3.模式 3-1气泡模式 3-2文本模式