C++利用sort进行排序

简介: C++利用sort进行排序

sort排序算法必须包含algorithm头文件

sort(a+m,a+n);//将数组a的下标为m的元素到下标为n-1的元素进行从小到大排序

sort(a+m,a+n,comp); //comp为自定义函数,可以自定义排序规则


1. #include<stdio.h>
2. #include<algorithm>
3. #include<iostream>
4. using namespace std;
5. int a[10]={10,75,1,56,87,22,7,6,13,91};
6. int my_comp(const int &a,const int &b)//建立从大到小排序的comp 
7. {return a>b;}//在两个元素相同时一定要返回0或者false 
8. int main()
9. {
10.   sort(a+0,a+10);
11.   for(int i=0;i<10;i++) printf("%d ",a[i]);
12.   sort(a+0,a+10,my_comp);
13.   for(int i=0;i<10;i++) printf("%d ",a[i]);
14.   return 0;
15. }


sort和struct结构体结合运用进行多特征排序


当我们采用sort()函数的默认规则排序结构体时,sort()默认结构体中的第一个成员为第一关键字,第二个成员为第二关键字,……,第N个元素为第N关键字,然后从小到大排序。

例如:我们要将学生的成绩从大到小排序,当成绩相同时,根据姓名字典序小的优先的规则排进行序。

例8.1   每当考试结束,老师总要对学生的成绩进行排序,以便研究学生学习情况。老师发现学生数目庞大,所以找来了会编程的你,并且它给你了全部同学的分数,希望你能按如下规则排序:1.分数高的排在前面;2.如果分数相同,就把名字字典序低的放在前面。

【输入格式】  

第一行一个整数n

接下来n行每行一个学生名字和一个分数。

【输出格式】  

每行一个名字和一个分数

【输入样例】

3

Xiaoxiao 396

Yingmo 405

Diyucailang 399

【输出样例】

Yingmo 405

Diyucailang 399

Xiaoxiao 396


1. #include<stdio.h>
2. #include<algorithm>
3. #include<string.h>
4. #include<iostream>
5. using namespace std;
6. 
7. struct student{
8.  char name[20];
9.  int score;
10. }a[100];
11. 
12. //建立多特征排序规则comp 
13. int score_comp(const student &a,const student &b)
14. {
15.   if(a.score>b.score) return 1;
16.   if(a.score<b.score) return 0;
17.   if(strcmp(a.name,b.name)<0) return 1;
18.   return 0; 
19. }
20. 
21. int main()
22. {
23.   int n;
24.   scanf("%d",&n);
25.   for(int i=0;i<n;i++){
26.     scanf("%s",a[i].name);
27.     scanf("%d",&a[i].score);
28.   }
29.   sort(a+0,a+n,score_comp);
30.   for(int i=0;i<n;i++) printf("%s %d\n",a[i].name,a[i].score);
31.   return 0;
32. }

 

相关文章
|
9月前
|
人工智能 算法 测试技术
【数学】【排序】【C++算法】3027人员站位的方案数
【数学】【排序】【C++算法】3027人员站位的方案数
|
1月前
|
存储 人工智能 算法
【C++数据结构——内排序】二路归并排序(头歌实践教学平台习题)【合集】
本关任务是实现二路归并算法,即将两个有序数组合并为一个有序数组。主要内容包括: - **任务描述**:实现二路归并算法。 - **相关知识**: - 二路归并算法的基本概念。 - 算法步骤:通过比较两个有序数组的元素,依次将较小的元素放入新数组中。 - 代码示例(以 C++ 为例)。 - 时间复杂度为 O(m+n),空间复杂度为 O(m+n)。 - **测试说明**:平台会对你编写的代码进行测试,提供输入和输出示例。 - **通关代码**:提供了完整的 C++ 实现代码。 - **测试结果**:展示代码运行后的排序结果。 开始你的任务吧,祝你成功!
36 10
|
1月前
|
搜索推荐 算法 数据处理
【C++数据结构——内排序】希尔排序(头歌实践教学平台习题)【合集】
本文介绍了希尔排序算法的实现及相关知识。主要内容包括: - **任务描述**:实现希尔排序算法。 - **相关知识**: - 排序算法基础概念,如稳定性。 - 插入排序的基本思想和步骤。 - 间隔序列(增量序列)的概念及其在希尔排序中的应用。 - 算法的时间复杂度和空间复杂度分析。 - 代码实现技巧,如循环嵌套和索引计算。 - **测试说明**:提供了测试输入和输出示例,帮助验证代码正确性。 - **我的通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了代码运行的测试结果。 通过这些内容,读者可以全面了解希尔排序的原理和实现方法。
58 10
|
1月前
|
搜索推荐 C++
【C++数据结构——内排序】快速排序(头歌实践教学平台习题)【合集】
快速排序是一种高效的排序算法,基于分治策略。它的主要思想是通过选择一个基准元素(pivot),将数组划分成两部分。一部分的元素都小于等于基准元素,另一部分的元素都大于等于基准元素。然后对这两部分分别进行排序,最终使整个数组有序。(第一行是元素个数,第二行是待排序的原始关键字数据。本关任务:实现快速排序算法。开始你的任务吧,祝你成功!
41 7
|
1月前
|
存储 算法 搜索推荐
【C++面向对象——群体类和群体数据的组织】实现含排序功能的数组类(头歌实践教学平台习题)【合集】
1. **相关排序和查找算法的原理**:介绍直接插入排序、直接选择排序、冒泡排序和顺序查找的基本原理及其实现代码。 2. **C++ 类与成员函数的定义**:讲解如何定义`Array`类,包括类的声明和实现,以及成员函数的定义与调用。 3. **数组作为类的成员变量的处理**:探讨内存管理和正确访问数组元素的方法,确保在类中正确使用动态分配的数组。 4. **函数参数传递与返回值处理**:解释排序和查找函数的参数传递方式及返回值处理,确保函数功能正确实现。 通过掌握这些知识,可以顺利地将排序和查找算法封装到`Array`类中,并进行测试验证。编程要求是在右侧编辑器补充代码以实现三种排序算法
40 5
|
8月前
|
C++ 容器
C++之deque容器(构造、赋值、大小、插入与删除、存取、排序)
C++之deque容器(构造、赋值、大小、插入与删除、存取、排序)
|
8月前
|
算法 搜索推荐 C++
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
C++之STL常用算法(遍历、查找、排序、拷贝、替换、算数生成、集合)
|
9月前
|
算法 搜索推荐 C++
浅谈sort函数底层(一道c++面试的天坑题)
浅谈sort函数底层(一道c++面试的天坑题)
|
9月前
|
算法 测试技术 C#
【模拟】【C++算法】2826. 将三个组排序
【模拟】【C++算法】2826. 将三个组排序
|
9月前
|
机器学习/深度学习 算法 调度
拓扑排序解析:计算机与数学的交汇点以及C++ 实现
拓扑排序解析:计算机与数学的交汇点以及C++ 实现
224 0