排序sort自定义
1.sort介绍
sort函数用于C 中,对给定区间所有元素进行排序,默认为升序,也可进行降序排序;
sort函数进行排序的时间复杂度为n*log2n,比冒泡之类的排序算法效率要高;
sort函数包含在头文件为#include<algorithm>的c 标准库中。
2.函数介绍
语法
Sort(start,end,cmp)
参数
(1)start表示要排序数组的起始地址;
(2)end表示数组结束地址的下一位;
(3)cmp用于规定排序的方法,可不填,默认升序。
功能
sort函数用于C 中,对给定区间所有元素进行排序,默认为升序,也可进行降序排序。
一般是直接对数组进行排序,例如对数组a[10]排序,sort(a,a 10)。而sort函数的强大之处在可与cmp函数结合使用,即排序方法的选择。
为什么要用c 标准库里的排序函数?
sort()函数是c 一种排序方法之一,相较冒泡排序和选择排序所带来的执行效率不高的问题,sort()函数使用的排序方法是类似于快速排序的方法,时间复杂度为n*log2(n),执行效率较高。
3.示例
示例一
sort函数没有第三个参数,实现的是从小到大(升序)排列
-
-
-
-
-
using namespace std;
-
-
int main()
-
-
{
-
-
int a[10]
-
-
for(int i=0;i<10;i )
-
-
cout<<a[i]<<endl;
-
-
sort(a,a 10);
-
-
for(int i=0;i<10;i )
-
-
cout<<a[i]<<endl;
-
-
return 0;
-
-
}
示例二
如何实现从大到小的排序?
这就如前文所说需要在sort()函数里的第三个参数了,告诉程序我要从大到小排序。
需要加入一个比较函数compare(),此函数的实现过程如下
-
bool compare(int a,int b)
-
-
{
-
-
return a>b;
-
-
}
实现从大到小的排序的方法
-
-
-
-
-
using namespace std;
-
-
bool compare(int a,int b)
-
-
{
-
-
return a>b;
-
-
}
-
-
int main()
-
-
{
-
-
int a[10];
-
-
for(int i=0;i<10;i )
-
-
cout<<a[i]<<endl;
-
-
sort(a,a 10,compare);//在这里就不需要对compare函数传入参数了
-
-
for(int i=0;i<10;i )
-
-
cout<<a[i]<<endl;
-
-
return 0;
-
-
}
结构体类型
-
struct node
-
-
{
-
-
int a;
-
-
int b;
-
-
double c;
-
-
}
有一个node类型的数组node arr[100],对它进行排序:先按a值升序排列,如果a值相同,再按b值降序排列,如果b还相同,就按c降序排列。就可以写一个比较函数
-
bool cmp(node x,node y)
-
-
{
-
-
if(x.a!=y.a) return x.a<y.a;
-
-
if(x.b!=y.b) return x.b>y.b;
-
-
return x.c>y.c;
-
-
}
4.例题
问题描述:
某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前 55 名学生发奖学金。期末,每个学生都有 33 门课的成绩:语文、数学、英语。先按总分从高到低排序,如果两个同学总分相同,再按语文成绩从高到低排序,如果两个同学总分和语文成绩都相同,那么规定学号小的同学 排在前面,这样,每个学生的排序是唯一确定的。
任务:先根据输入的 33 门课的成绩计算总分,然后按上述规则排序,最后按排名顺序输出前五名名学生的学号和总分。注意,在前 55 名同学中,每个人的奖学金都不相同,因此,你必须严格按上述规则排序。例如,在某个正确答案中,如果前两行的输出数据(每行输出两个数:学号、总分) 是:
77 279279
55 279279这两行数据的含义是:总分最高的两个同学的学号依次是 77 号、55 号。这两名同学的总分都是 279279 (总分等于输入的语文、数学、英语三科成绩之和) ,但学号为 77 的学生语文成绩更高一些。如果你的前两名的输出数据是:
55 279279
77 279279则按输出错误处理,不能得分。
输入
共 n 1n 1行。
第 11 行为一个正整数n ( \le 300)n(≤300),表示该校参加评选的学生人数。
第 22 到 n 1n 1 行,每行有 33 个用空格隔开的数字,每个数字都在 00 到 100100 之间。第 jj 行的 33 个数字依次表示学号为 j-1j−1 的学生的语文、数学、英语的成绩。每个学生的学号按照输入顺序编号为 1\sim n1∼n(恰好是输入数据的行号减 11)。
所给的数据都是正确的,不必检验。
//感谢 黄小U饮品 修正输入格式
输出
共 55 行,每行是两个用空格隔开的正整数,依次表示前 55 名学生的学号和总分。
Sample 1
Inputcopy Outputcopy 6 90 67 80 87 66 91 78 89 91 88 99 77 67 89 64 78 89 98
6 265 4 264 3 258 2 244 1 237
Sample 2
Inputcopy Outputcopy 8 80 89 89 88 98 78 90 67 80 87 66 91 78 89 91 88 99 77 67 89 64 78 89 98
8 265 2 264 6 264 1 258 5 258
代码
-
-
-
using namespace std;
-
-
struct stu
-
{
-
int number;
-
int Chinese,Math,English;
-
int sum;
-
}student[500];
-
-
bool cmp(stu a,stu b)
-
{
-
if(a.sum==b.sum&&a.Chinese==b.Chinese) return a.number<b.number;
-
else if(a.sum==b.sum) return a.Chinese>b.Chinese;
-
return a.sum>b.sum;
-
}
-
-
int main(void)
-
{
-
int n;
-
-
scanf("%d",&n);
-
for(int i=1;i<=n;i )
-
{
-
student[i].number=i;
-
scanf("%d%d%d",&student[i].Chinese,&student[i].Math,&student[i].English);
-
student[i].sum=student[i].Chinese student[i].Math student[i].English;
-
}
-
sort(student 1,student n 1,cmp);
-
-
for(int i=1;i<=5;i )
-
printf("%d %d\n",student[i].number,student[i].sum);
-
-
return 0;
-
}
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhfijgaj
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
excel下划线不显示怎么办
PHP中文网 06-23 -
怎样阻止微信小程序自动打开
PHP中文网 06-13 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
photoshop蒙版画笔没反应怎么办
PHP中文网 06-24