【C++进阶】竞赛常用库函数

news2024/11/16 2:45:20

一、排序

sort简介

  • sort函数包含在头文件<algorithm>中。
  • 在使用前需要#include <algorithm>或使用万能头文件。
  • sort是C++标准库中的一个函数模板,用于对指定范围内的元素进行排序。
  • sort算法使用的是快速排序(QuickSort)或者类似快速排序的改进算法,具有较好的平均时间复杂度, 一般为O(nlogn)。

sort用法

sort(起始地址,结束地址的下一位,*比较函数);

#include <iostream>
#include <algorithm>
//#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);
for(int i = 1; i <= n; i++)cout<<a[i]<<' ';
}

sort(起始地址,结束地址的下一位,*比较函数);

#include <iostream>
#include <algorithm>
#include <vector>
//#include <bits /stdc++.h>
using namespace std ;


int main()
{
vector<int> v = {5, 1, 3, 9, 11};
sort(v.begin(),v.end());
for(int i = 0; i < v.size(); ++i)cout<<v[i]<<" ";
}


 自定义比较函数

  • sort默认使用小于号进行排序,如果想要自定义比较规则,
  • 可以传入第三个参数,可以是函数或lambda表达式。
#include <iostream>
#include <algorithm>
#include <vector>
//#include <bits /stdc++.h>
using namespace std ;

bool cmp(const int &u, const int &v)
{
    return u > v;
}
int main()
{
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    vector<int> v = {5, 1, 3, 9, 11};
    sort(v.begin(),v.end(),cmp);
    for(int i = 0; i < v.size(); ++i)cout<<v[i]<<" ";
}
#include <iostream>
#include <algorithm>
#include <vector>
//#include <bits /stdc++.h>
using namespace std ;

bool cmp(const int &u, const int &v)
{
    return u > v;
}
int main()
{
    ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
    vector<int> v = {5, 1, 3, 9, 11};
    sort(v.begin(),v.end(),[](const int &u,const int &v){return u > v;});
    for(int i = 0; i < v.size(); ++i)cout<<v[i]<<" ";
}

二、最值查找函数

min 和 max函数

min(a, b)返回a和b中较小的那个值,只能传入两个值,或传入一个列表。
例如:
min(3, 5)= 3
min({1,2,3, 4})= 1
max(a, b)返回a和b中较大的那个值,只能传入两个值,或传入一个列表。
例如:
max(7, 5)= 7
min({1,2,3, 4})= 4
时间复杂度为O(1),传入参数为数组时时间复杂度为O(n), n为数组大小。
min,max函数是在取最值操作时最常用的操作。


min_ element和max_ element

min_ element(st, ed)返回地址[st, ed)中最小的那个值的地址(迭代器) ,传入参数为两个地址或迭代器。
max_ element(st, ed)返回地址[st, ed)中最大的那个值的地址(迭代器),传入参数为两个地址或迭代器。
时间复杂度均为O(n), n为数组大小(由传入的参数决定)。

#include<iostream>
using namespace std;


int main(void) {
    vector<int> v = {5,1,3,9,11}
    cout<< *max_element(v.begin(),v.end())<<endl;
	return 0;
}


nth_ element函数

nth_ element(st, k, ed)
进行部分排序,返回值为void()
传入参数为三个地址或迭代器。其中第二个参数位置的元素将处于正确位置,其他位置元素的顺序可能是任意的,但前面的都比它小,后面的都比它大。
时间复杂度O(n)。

#include<iostream>
#include<algorithm> 
#include<vector>
using namespace std;


int main(void) {
    vector<int> v = {5,1,3,9,11};
    nth_element(v.begin(),v.begin()+3, v.end());
    for (auto &i : v)cout<<i<<" ";
	return 0;
}

三、二分查找

二分查找的前提

库函数只能对数组进行二分查找。
对一个数组进行二分查找的前提是这个数组中的元素是单调的,一般为单调不减,当然如果是单调不增也可以(需要修改比较函数)。例如:
[1, 5,5,9,18]是单调的[1,9,9,7,15]不是单调的[9,8,8,7,7,1]是单调的

binary_search 函数

binary_search是C++标准库中的一个算法函数,用于在已排序的序列(例如数组或容器)中查找特定元素。
它通过二分查找算法来确定序列中是否存在目标元素。
函数返回一个bool值,表示目标元素是否存在于序列中。如果需要获取找到的元素的位置,可以使用
std:lower_bound函数或std:upper_bound函数。

#include<iostream>
#include<algorithm> 
#include<vector>
using namespace std;


int main(void) {
    vector<int> v = {1,2,3,4,5};
    int target = 5;
    bool  found = binary_search(v.begin(), v.end(), target);
    if (found) cout<< "yes";
    else cout<<"not exist";
	return 0;
}

lower_bound 和 upper_bound

前提:数组必须为非降序。
如果要在非升序的数组中使用,可以通过修改比较函数实现(方法与sort自定义比较函数类似)。lower_bound(st, ed,x)返回地址[st, ed)中第一个小于等于x的元素的地址。
upper_bound(st, ed,x)返回地址[st, ed)中第一个大于x的元素的地址。如果不存在则返回最后一个元素的下一个位置,在vector中即end()。

#include<iostream>
#include<algorithm> 
#include<vector>
using namespace std;


int main(void) {
    vector<int> v = {1,5,7,3,11,8,9};
    sort(v.begin(), v.end()) ;
	cout<< *lower_bound(v.begin(), v.end(), 8) <<endl;
	return 0;
}

四、大小写转换

islowerlisupper 函数

slower和isupper是C++标准库中的字符分类函数,用于检查一个字符是否为小写字母或大写字母。islower和isupper函数需要包含头文件<cctype>,也可用万能头包含。
函数返回值为bool类型。

tolowerl/toupper函数

tolower(char ch)可以将ch转换为小写字母,如果ch不是大写字母则不进行操作。toupper()同理。
 

ascll 码

#include<iostream>
#include<algorithm> 
#include<vector>
using namespace std;

void ConvertCh(char &i){
	if('a' < i && i < 'z') i = i - 'a' + 'A';
	else if ('A' <= i && i > 'Z') i = i - 'A' + 'a';
}

int main(void) {
	string s;
	cin>>s;
	for (auto &i : s) ConvertCh(i);
	cout<< s;
	return 0;
}

五、next_permutation() 函数

next_permutation函数用于生成当前序列的下一个排列。它按照字典序对序列进行重新排列,如果存在下一个排列,则将当前序列更改为下一个排列,开返回true;如来刖序列一经是最后一个排列,则将序列更改为第一个排列,并返回false。

#include<iostream>
#include<algorithm> 
#include<vector>
using namespace std;


int main(void) {
	vector<int> nums = {1, 2, 3};
	cout<<"Initial Num:"<<" ";
	for(int num : nums){
		cout<< num <<" "; 
	}
	cout<< endl;
	while (next_permutation(nums.begin(),nums.end())){
		cout << "Next permutation:";
		for(int num: nums){
			cout << num <<" ";
		}
		cout << endl;
	}
	return 0;
}

preu_permutation()函数

preu_permutation函数与next_permutation函数相反,它用于生成当前序列的上一个排列。它
按照字典序对序列进行重新排列,如果存在上一个排列,则将当前序列更改为上一个序列,并返回true;如果当前序列已经是第一个排列,则将序列更改为最后一个排列,并返回false。
 

六、memset() 函数

memset()是一个用于设置内仔块值的函数。
它的原型定义在<cstring>头文件中,函数的声明如下:
void*memset(void* ptr,int value,size_t num);
memset()函数接受三个参数:
1.ptr:指向要设置值的内存块的指针。2.value:要设置的值,通常是一个整数(8位二进制数)。3.num:要设置的字节数。
memset()函数将ptr指向的内存块的前num个字节设置为value的值。它返回
一个指向ptr的指针。
memset()函数通常用于初始化内存块,将其设置为特定的值。
例如,如果要将一个整型数组的所有元素设置为0,可以使用memset()函数如下

int arr[10j;
memset(arr,0,sizeof(arr));
#include<iostream>
#include<algorithm> 
#include<vector>
#include<cstring>
#include<bitset>
using namespace std;


int main(void) {
	int a[5];
	memset(a, 1, sizeof(a));
	for(int i = 0; i < 5; i++) cout<<bitset<32>(a[i])<<endl;
	return 0;
}

七、swap() 函数

swap(T &a,T &b)函数接受两个参数:
1.a:要交换值的第一个变量的引用。2.b:要交换值的第二个变量的引用。
swap()函数通过将第一个变量的值存储到临时变量中,然后将第二个变量的值赋给第一个变量,最后将临时变量的值赋给第二个变量,实现两个变量值的交换。
swap()函数可以用于交换任意类型的变量,包括基本类型(如整数、浮点数等)和自定义类型(如结构体、类对象等))。
 

八、reverse() 函数

reverse()是一个用于反转容器中元素顺序的函数。
它的原型定义在<algorithm>头文件中,函数的声明如下:

template<class BidirIt>
void reverse(BidirIt first,Bidirit last);
 reverse()函数接受两个参数:
1.first:指向容器中要反转的第一个元素的迭代器。
2.last:指向容器中要反转的最后一个元素的下一个位置的迭代器。reverse()函数将[first, last)范围内的元素顺序进行反转。
也就是说,它会将[first, last)范围内的元素按相反的顺序重新排列。reverse()函数可用于反转各种类型的容器,包括数组、向量、链表等。
以下是一个示例,展示如何使用reverse()函数反转一个整型向量的元素顺序:

#include<iostream>
#include<algorithm> 
#include<vector>
#include<cstring>
#include<bitset>
using namespace std;


int main(void) {
	vector<int> v = {1,2,3};
	reverse(v.begin(), v.end());
	
	for(int num : v){
		cout<< num <<" ";
	}
	
	cout<< endl;
	return 0;
}

在上述示例中,std:reverse(vec.begin().
vec.end())将整型向量vec中的元素顺序进行反转。最终输出的结果是54321。
需要注意的是,reverse()函数只能用于支持双向迭代器的容器,因为它需要能够向前和向后遍历容器中的元素。对于只支持单向迭代器的容器(如前向链表),无法使用reverse()函数进行反转。

九、unique() 函数

unique()是一个用于去除容器中相邻重复元素的函数。它的原型定义在<algorithm>头文件中,函数的声明如下:
unique(first, last) 函数接受两个参数:
1.first:指向容器中要去重的第一个元素的迭代器。
2.last:指向容器中要去重的最后一个元素的下一个位置的迭代器。
unique()函数将[first, last)范围内的组邻重复元素去除,并返回一个指向去重后范围的尾后迭代器去重后的范围中只保留了第一个出现的元素,后续重复的元素都被移除。
unique()函数可用于去除各种类型的容器中的相邻重复元素,包括数组、向量、链表等。
 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1543234.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

OCP NVME SSD规范解读-14.Firmware固件升级要求

4.11节 Firmware Update Requirements 描述了数据中心NVMe SSD固件更新的具体要求&#xff0c;确保固件升级过程既安全又可靠&#xff0c;同时充分考虑了设备在升级过程中的可用性和功能性。 FWUP-1: 设备必须记录每一次固件激活过程。这意味着固件升级过程中&#xff0c;设备会…

一文搞懂 YOLOv9 训练推理全流程 | YOLOv9你绝对不知道的细节!

文章地址&#xff1a;https://arxiv.org/pdf/2402.13616.pdf 代码地址&#xff1a;https://github.com/WongKinYiu/yolov9 前言 在这篇博客中&#xff0c;我们来聊聊 YOLOv9。首先&#xff0c;值得注意的一点是&#xff0c;YOLOv9的变化相对较小&#xff0c;它仍然基于YOLOv5的…

在线影院项目话术(0.7w精选)

项目介绍 这个电影院项目不同于常见的基于会员限制用户观看范围的在线影院项目&#xff0c;主要就是按需购买片源来进行观看&#xff0c;用户就不会因高额的会员费而劝退。 项目的主要实现就是&#xff1a;微服务的五大主键&#xff0c;数据库使用mysql,redis&#xff0c;中间…

2024年湖北荆门市工程系列职称评审开始啦

(一)中级测试对象&#xff1a;拟参加近两年度相关系列(专业)中级技术职务评审&#xff0c;且未取得中级水平能力测试合格证书的专业技术人员。 (二)初级测试对象&#xff1a;拟参加近两年度档案专业、工程系列助理级职称评审&#xff0c;且未取得初级水平能力测试合格证书的专业…

白酒:陈酿过程中的老熟度评价与品质提升方法

在豪迈白酒的酿造过程中&#xff0c;陈酿是一个至关重要的环节。陈酿不仅能使白酒老熟&#xff0c;提品质&#xff0c;还能发展出与众不同的风味和口感。云仓酒庄深知陈酿的重要性&#xff0c;并进行了深入的研究和实践。本文将探讨陈酿过程中的老熟度评价与品质提升方法。 首先…

蓝桥杯day7刷题日记

P8697 [蓝桥杯 2019 国 C] 最长子序列 思路&#xff1a;直接遍历&#xff0c;和子序列相同就记录&#xff0c;不然就下一位 #include <iostream> #include <string> using namespace std; int res;int main() {string s,t;cin>>s>>t;int i0,j0;while…

IDEA 远程调试

1.什么是远程调试 Java提供了一个远程调试功能&#xff0c;支持设置断点及线程级的调试同时&#xff0c;不同的JVM通过接口的协议联系&#xff0c;本地的Java文件在远程JVM建立联系和通信。 2.服务端开启远程调试 开启远程调试功能&#xff0c;需要修改tomcat 的catalina.sh…

目录框架【欢迎订阅收藏】

前端篇 第一章vue.js 1.Vue.js入门及环境搭建 2.vue.js基础知识 3.Vue.js自定义组件 Vue.js路由 5.Vue.js状态管理 6.网络通信axios 第二章Tailwindcss 1.tailwindcss介绍及引入 2.基础样式 3.组件样式 4.工具样式 第三章Nuxt 1.nuxt介绍及环境搭建 2.nuxt 目录结构 3.nuxt …

ElasticSearch文档批量操作[ES系列] - 第503篇

历史文章&#xff08;文章累计500&#xff09; 《国内最全的Spring Boot系列之一》 《国内最全的Spring Boot系列之二》 《国内最全的Spring Boot系列之三》 《国内最全的Spring Boot系列之四》 《国内最全的Spring Boot系列之五》 《国内最全的Spring Boot系列之六》 《…

超声波清洗机怎么选?过来人推荐四大表现突出的宝藏眼镜清洗机!

如果你清洁眼镜的时候总是习惯用纸巾或者是衣服擦的话&#xff0c;我劝你要赶紧把这个坏习惯给改掉&#xff01;很多不知道原因的朋友会问&#xff0c;为什么不能用纸巾擦眼镜&#xff1f;其实是因为纸巾还有衣服布料上&#xff0c;存在一些比较粗糙的微粒&#xff0c;人体手部…

车载测试 HIL测试详解

HIL测试&#xff1a;即硬件在环测试&#xff0c;是一种广泛应用于汽车电子控制系统领域的测试方法。它将实际的硬件&#xff08;如ECU、传感器、执行器等&#xff09;与模拟器件&#xff08;如模型、仿真器等&#xff09;通过接口连接起来&#xff0c;模拟实际的操作环境&#…

动态规划-----最长公共子序列(及其衍生问题)

目录 一.最长公共子序列的基本概念&#xff1a; 解决动态规划问题的一般思路&#xff08;三大步骤&#xff09;&#xff1a; 二.最长公共子序列题目&#xff1a; 三.字符串的删除操作&#xff1a; 四.最小 ASCII 删除和&#xff1a; 一.最长公共子序列的基本概念&#xff…

微前端——qiankun

一、微前端 微前端是指存在于浏览器中的微服务&#xff0c;其借鉴了后端微服务的架构理念&#xff0c;将微服务的概念扩展到前端。即将一个大型的前端应用拆分为成多个模块&#xff0c;每个微前端模块可以有不同的团队开发并进行管理&#xff0c;且可以自主选择框架&#xff0…

seata测试demo(订单)

seata工作流程: seata对分布式事务的协调和控制就是31 1>XID&#xff1a;XID是全局事务的唯一标识&#xff0c;它可以在服务的调用链路中传递&#xff0c;绑定到服务的事务上下文中。 3>TC->TM->RM TC:事务协调器>就是seata 负责维护全局事务和分支事务的状…

选项式API和组合式API的区别

选项式(options) API 和组合式(composition) API两种不同的风格书写&#xff0c;Vue3 的组件可以使用这两种api来编写。 选项式API和组合式API的区别 选项式API 选项式 API&#xff0c;具有相同功能的放在一起&#xff0c;可以用包含多个选项的对象来描述组件的逻辑&…

【周总结】

周总结 完成项目混合版时区改造 完成相关jira问题的修改 完成老版本APP数据保存接口的兼容&#xff0c;手动赋值时区 2024/03/24 天气阴 一点不冷 1.Its time to go、Spring is coming&#xff01; 2. Its a nice day that staying with friends in a peaceful …

初探Ruby编程语言

文章目录 引言一、Ruby简史二、Ruby特性三、安装Ruby四、命令行执行Ruby五、Ruby的编程模型六、案例演示结语 引言 大家好&#xff0c;今天我们将一起探索一门历史悠久、充满魅力的编程语言——Ruby。Ruby是由松本行弘&#xff08;Yukihiro Matsumoto&#xff09;于1993年发明…

LangChain核心模块 Retrieval——文档加载器

Retrieval ​ 许多LLM申请需要用户的特定数据&#xff0c;这些数据不属于模型训练集的一部分&#xff0c;实现这一目标的主要方法是RAG(检索增强生成)&#xff0c;在这个过程中&#xff0c;将检索外部数据&#xff0c;然后在执行生成步骤时将其传递给LLM。 ​ LangChain 提供…

Linux系统安装openGauss结合内网穿透实现公网访问本地数据库管理系统——“cpolar内网穿透”

文章目录 前言1. Linux 安装 openGauss2. Linux 安装cpolar3. 创建openGauss主节点端口号公网地址4. 远程连接openGauss5. 固定连接TCP公网地址6. 固定地址连接测试 前言 openGauss是一款开源关系型数据库管理系统&#xff0c;采用木兰宽松许可证v2发行。openGauss内核深度融合…

力扣:205. 同构字符串

前言&#xff1a;剑指offer刷题系列 问题&#xff1a; 给定两个字符串 s 和 t &#xff0c;判断它们是否是同构的。 如果 s 中的字符可以按某种映射关系替换得到 t &#xff0c;那么这两个字符串是同构的。 每个出现的字符都应当映射到另一个字符&#xff0c;同时不改变字符…