蓝桥杯省赛无忧 竞赛常用库函数 课件5 排序

01 sort简介

02 sort的用法

cpp 复制代码
sort(起始地址,结束地址的下一位,比较函数);默认用小于号
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	int a[1000];
	int n;
	//读取数组大小
	cin>>n;
	//读取元素
	for(int i=1;i<=n;i++)cin>>a[i];
	//对数组进行排序 
	sort(a+1,a+n+1);//[1,n+1)左闭右开;a+1指a[1],a+n+1指a[n] 
	//输出
	for(int i=1;i<=n;i++)cout<<a[i]<<' ';
	return 0; 
}
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	//初始化v
	vector<int> v={5,1,3,9,11};
	//对数组进行排序
	sort(v.begin(),v.end());
	//输出
	for(int i=0;i<v.size();i++) cout<<v[i]<<' ';
}

03 自定义比较函数



04 例题讲解

https://www.lanqiao.cn/problems/1265/learning/?page=1\&first_category_id=1\&problem_id=1265

输入

cpp 复制代码
5
1 3 2 6 5

输出

cpp 复制代码
1 2 3 5 6
6 5 3 2 1
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int N=1e6+3;
int main()
{
  int a[N];
  int n;
  cin>>n;
  for(int i=1;i<=n;i++)cin>>a[i];
  sort(a+1,a+n+1);
  for(int i=1;i<=n;i++)cout<<a[i]<<' ';
  cout<<endl;
  for(int i=n;i>=1;i--)cout<<a[i]<<' ';
  return 0;
}
相关推荐
郭逍遥2 分钟前
[Godot] JPS跳点寻路和RVO避障
算法·godot·启发式算法
rgb2gray6 分钟前
论文详解:基于POI数据的城市功能区动态演化分析——以北京为例
人工智能·算法·机器学习·回归·gwr
m0_734998017 分钟前
Day 26
数据结构·c++·算法
信奥卷王19 分钟前
2026年03月GESPC++二级真题解析(含视频)
算法
从零开始学习人工智能23 分钟前
国产阿特拉斯无人机蜂群核心算法(一)
算法·无人机
爱编码的小八嘎32 分钟前
C语言完美演绎6-4
c语言
励志的小陈1 小时前
双指针算法--移除元素、删除有序数组中的重复项、合并两个有序数组
算法
Summer_Uncle1 小时前
【QT学习】Qt界面布局的生命周期和加载时机
c++·qt
小CC吃豆子1 小时前
C++ 继承
开发语言·c++
hoiii1871 小时前
Mean Shift目标跟踪算法MATLAB实现
算法·matlab·目标跟踪