C++常用库函数

news2024/11/27 14:35:50

大小写转换

islower/isupper函数

用于检查一个字符是否为小写或大小字母,需要包含头文件< cctype >,也可以包含万能头文件< bits/stdc++.h >.函数返回值类型为bool类型。

int main()
{
	char ch1 = 'A';
	char ch2 = 'b';
	//使用islower函数判断是否为小写字母
	if (islower(ch1))
	{
		cout << ch1 << "是小写" << endl;
	}
	else
	{
		cout << ch1 << "是大写" << endl;
	}

	if (isupper(ch2))
	{
		cout << ch2 << "是大写" << endl;
	}
	else
	{
		cout << ch2 << "是小写" << endl;
	}
	return 0;
}

tolower/toupper函数

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

int main()
{
	char ch1 = 'A';
	char ch2 = 'b';
	char lowerCh1 = tolower(ch1);
	cout << ch1 << "的小写" << lowerCh1 << endl;
	char upperCh2 = toupper(ch2);
	cout << ch2 << "的大写" << upperCh2 << endl;
	return 0;
}

ASCII码

我们绕过’c’-‘a’+‘A’=‘C’;
在ASCLL码表中,大写字母的编码范围是65(‘A’)到90(‘Z’),而小写字母的编码范围是97(‘a’)到122(‘z’)根据这个规则,可以使用ASCLL码表进行大小写转换。
数字6也可以以通过字符转化而来’6’-‘0’=6.

排序

sort函数

在使用前需要加头文件#incldue< algorithm >,或用万能头文件。sort是C++标准库中的函数模板,用于指定范围的元素内的排序
sort算法使用的是快速排序,平局时间复杂度一般为O(nlogn)。

sort函数用法

sort(起始地址,结束地址的下一位,*比较函数)
注意(*表示可有可不有。)

#include<algorithm>
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);//从a[1]到a[n+1] [1,n+1)左闭右开
	for (int i = 1; i <= n; i++)
	{
		cout << a[i] << ' ';
	}
}

运行结果:
在这里插入图片描述

#include<vector>
int main()
{
	vector<int>v = { 5,2,8,9,7 };
	//容器用迭代器
	sort(v.begin(), v.end());
	for (auto& i : v)
	{
		cout << i << ' ';
	}
	return 0;
}

运行结果:
在这里插入图片描述

自定义比较函数

sort默认使用小于号,要是想自定义比较规则,可以传入第三个参数,可以是函数或lambda表达式(匿名函数)

#include<vector>
//比较函数
bool cmp(const int& u, const int& v)
{
	return u > v;
}

int main()
{
	vector<int>v = { 5,2,8,9,7 };
	//容器用迭代器
	sort(v.begin(), v.end(),cmp);
	for (auto& i : v)
	{
		cout << i << ' ';
	}
	return 0;
}

运行结果:
在这里插入图片描述

int main()
{
	vector<int>v = { 3,2,6,1,5 };
	//用lambda表达式
	sort(v.begin(), v.end(), [](const int& u, const int& v)
		{
			return u > v;
		});
	for (auto& i : v)
	{
		cout << i << ' ';
	}
}

在这里插入图片描述

结构体比较

结构体可以使用小括号重载后进行排序,当然用前面的方法也是可行的

struct Node
{
	int u, v;
	bool operator<(const Node& m)const
	{
		//以u为第一关键字,v为第二关键字
		return u == m.u ? v < m.v : u < m.u;
	}
};

memset()

memset()是一个用于设置内存块值的函数
memset()函数接受三个参数:
1.ptr:指向要设置值的内存块的指针。
2.value:要设置的值,通常是一个整数。
3.num:要设置的字节数。
memset()函数将ptr指向的内存块的前num个字节设置为value的值。它返回一个指向ptr的指针。memset()函数通常用于初始化内存块,将其设置为特定的值。
例如,如果要将一个整型数组的所有元素设置为0,可以使用memset()函数如下:int arr[10];memset(arr, 0, sizeof(arr));
在上述示例中,memset(arr,0,sizeof(arr))将数组arr的所有元素设置为0。
需要注意的是,memset()函数对于非字符类型的数组可能会产生未定义行为。在处理非字符类型的数组时,更好使用C++中的其他方法,如循环遍历来初 组memset会将每个byte设置为value。

#include<cstring>
int main()
{
	int a[5];
	memset(a, 0, sizeof(a));
	for (auto i : a)
	{
		cout << i << ' ';
	}

}

在这里插入图片描述
当我们初始化1时结果和我们预想的不一样
在这里插入图片描述
因为它把四个byte都设成1,因为int是32bit,所以我们会得到00000001 00000001 00000001 00000001
我们一般都将其设置为0,-1(补码是全部都是1),0x3f(0x表示16进制,一个很大的整数)
在这里插入图片描述
在这里插入图片描述

swap()

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

reverse()

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

在这里插入图片描述

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

unique()

用于去除容器中相邻重复的元素函数
unique(first,last)函数接受两个参数:
1.first:指向容器中要去重的第一个元素的迭代器。
2.last:指向容器中要去重的最后一个元素的下一个位置的迭代器。
unique()函数将[first, last)范围内的相邻重复元素去除,并返回一个指向去重后范围的尾的尾后迭代器,去重后的范围中只保留了第一个出现的元素,后续重复的元素都被移除。
unique()函数可用于去除各种类型的容器中的相邻重复元素,包括数组、向量、链表等。以下是一个示例,展示如何使用unique()函数去除一个整型向量中的相邻重复元素:
在这里插入图片描述
unique返回的是5后面那个4的迭代器或者地址
注意:
在上述示例中,unique(v.begin(),v.end())将整型向量vec中的相邻重复元素去除。最终输出的结果是12345。
需要注意的是,unique()函数只能去除相邻的重复元素,如果容器中存在非相邻的重复元素,则无法去除。
如果需要去除所有重复元素,而不仅仅是相邻的重复元素,可先对容器进行排序,然后再使用unique()函数。
unique()时间复杂度为O(n)。
在这里插入图片描述

排列

next_permutation()函数

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

prev_permutation()函数

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

我们一般是用搜索来求一个数组的全排列。
假如我们从中间开始排列
在这里插入图片描述

最值查找

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为数组大小(由传入的参数决定)。
在这里插入图片描述

nth_element函数

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

二分查找

binary_search

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

lower_bound和upper_bound

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

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

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

相关文章

springboot+react实现移动端相册(上传图片到oss/ 批量删除/ 查看图片详情等功能)

相册页面及功能展示&#xff1a; react前端结构及代码&#xff1a; Java后端结构及代码 数据库结构&#xff1a; photo&#xff1a; user 这是首个利用AI自有知识构建的简易相册系统&#xff0c;项目是react构造前端spring boot构造后端。 前端有四个主要页面&#xff1…

深入理解Transformer的笔记记录(精简版本)NNLM → Word2Vec

文章的整体介绍顺序为: NNLM → Word2Vec → Seq2Seq → Seq2Seq with Attention → Transformer → Elmo → GPT → BERT 自然语言处理相关任务中要将自然语言交给机器学习中的算法来处理,通常需要将语言数学化,因为计算机机器只认数学符号。向量是人把自然界的东西抽象出…

MySQL创建电子订阅表相关指令(创建,删除,查询,说明,添加)

利用以下代码创建一个名字为one的数据库。 查看数据库是否创建完成 。 创建一个在one数据库中的表格&#xff0c;括号里是字段名和数据类型&#xff0c;用逗号隔开&#xff0c;给id设置主键&#xff0c;确保id的唯一性。 INSERT INTO 为添加数据&#xff0c;one.subscribe中o…

第 1 章 MyBatis快速入门

1.1 ORM简介 ORM&#xff08;Object Relational Mapping&#xff0c;对象——关系映射&#xff09;框架的主要功能是根据映射配置文件&#xff0c;完成数据在对象模型与关系模型之间的映射&#xff0c;同时出屏蔽了连接数据库、创建 Statement 对象、执行 SQL、读取 ResultSet…

DSP 如何在调试时便捷查看数组元素

背景描述: 在CCS调试过程中&#xff0c;需要查看一些变量的值&#xff0c;但是数组只能显示第一个元素的值&#xff0c;不能全部展示出来&#xff0c;这样就不便于查看了。 解决方法: 找到变量显示窗口 选中数组右键 设置开始元素和需要展示的个数 这样就可以把数组展开…

Java->Map和Set

目录 一、搜索树 1.概念 2.查找 3.插入 4.删除 二、搜索 1.Map的使用 1.1关于map的说明 1.2map的常用方法 2.Set的使用 2.1关于set的说明 2.2set的常用方法 三、哈希表 1.概念 2. 哈希冲突 3.冲突避免 3.1哈希函数的设计 3.2负载因子调节 4.解决冲突 4.1闭…

3 机器学习之假设空间

归纳(induction)与演绎(deduction)是科学推理的两大基本手段。前者是从特殊到一般的“泛化”(generalization)过程&#xff0c;即从具体的事实归结出一般性规律&#xff1b;后者则是从一般到特殊的“特化”(specialization)过程&#xff0c;即从基础原理推演出具体状况。例如&a…

一款功能强大的颜色选择工具ColorPicker

ColorPicker 是一款轻量级且功能强大的颜色选择工具&#xff0c;专为设计师、开发者以及需要在日常工作中处理颜色的用户设计。该工具允许用户从屏幕上的任意位置快速获取颜色代码&#xff0c;并提供多种格式的颜色值输出&#xff0c;包括RGB、HEX、HSB等。 ColorPicker的界面…

YOLO的相关改进机制

我的面包多平台有多种关于YOLO的改进&#xff0c;大家尽早关注&#xff0c;不迷路

opencv 答题卡检测项目实现

在教育和考试领域&#xff0c;答题卡自动评分系统能够大大提高效率和准确性。本文将介绍如何使用OpenCV库实现一个简单的答题卡检测项目。这个项目包括读取图像、检测答题卡轮廓、透视变换、二值化处理、检测选择题答案&#xff0c;并最终计算得分。 导入库和定义常量 import …

动态规划-路径问题——931.下降路径最小和

1.题目解析 题目来源&#xff1a;931.下降路径最小和——力扣 测试用例 2.算法原理 1.状态表示 我们可以开辟一个dp表&#xff0c;多开辟一行两列用来存储虚拟位置&#xff0c;dp[i][j]表示从第一行到该位置的最小路径和 2.状态转移方程 由于要找到最小路径和&#xff0c;并且由…

中间件镜像升级策略

进入集群 kubectl edit deployments paas-bmm-v1 -n kube-system 修改容器 abcsys.cn:5000/boc3.7/bmm-web-v4:latest-202410091355

【芯片知识】 | 浅谈NRK3502语音芯片IC的工作原理

随着科技的快速发展&#xff0c;语音技术逐渐渗透到我们生活的各个领域&#xff0c;如智能家居、车载导航、手机通讯等。作为语音技术的核心&#xff0c;语音芯片在其中发挥着重要作用。今天&#xff0c;我们将深入探讨NRK3502这款先进的语音芯片IC的工作原理&#xff0c;以及它…

动态规划-路径问题——174.地下城游戏

1.题目解析 题目来源&#xff1a;174.地下城游戏 测试用例 2.算法原理 1.状态表示 通常dp[i,j]可以表示终点也可以表示起点&#xff0c;在本题中如果表示为终点&#xff0c;即勇士到[i,j]位置所需要的最小生命值&#xff0c;但是由于后续位置的未知无法向后继续判断&#xff…

如何判断外包建站公司靠谱与否?2024外包网站设计公司哪家好top3

要知道一家网站建设公司靠不靠谱&#xff0c;看他们合作过哪些公司就能知道个大概。 如果服务对象有各行业的头肩部企业&#xff0c;那这家网站建设公司在专业性上肯定是有保障的。 但是&#xff0c;靠谱并不意味着适合自己。 靠谱的网站建设公司其实在技术上都大差不差&…

我用这四款翻译工具,轻松搞定英文在线翻译

作为一名喜欢搜罗各种办公软件的打工人&#xff0c;今天我要和大家聊聊一个我们工作中不可或缺的技能——英文翻译。首先&#xff0c;我们得承认&#xff0c;翻译工作有时候真的很让人头疼&#xff0c;尤其是当我们面对一堆专业术语和长篇大论时。但自从我发现了这些翻译神器&a…

Linux系统:apt-get update 和apt update区别

apt-get update 和apt update区别 ‌apt-get update和apt update的主要区别在于它们所属的命令集以及在现代Ubuntu系统中的使用推荐。‌ ‌所属命令集‌&#xff1a;apt-get update是apt-get命令的一部分&#xff0c;而apt update是apt命令的一部分。apt是apt-get的替代工具&am…

《Image Processing GNN: Breaking Rigidity in Super-Resolution》CVPR2024

摘要 这篇论文提出了一种名为Image Processing Graph Neural Networks (IPG) 的模型&#xff0c;旨在通过利用图的灵活性来突破超分辨率&#xff08;Super-Resolution, SR&#xff09;中的固有刚性问题。在现有的SR模型中&#xff0c;无论是基于卷积神经网络&#xff08;CNNs&…

新手小白想快速上手Mac的使用必看问题

相信不论是现在还是将来&#xff0c;肯定还是会有Mac小白的存在&#xff0c;对于大多数人来说&#xff0c;从小接触Windows的机会比较多&#xff0c;Windows的使用也是比较多&#xff0c;但是有些朋友在大学的时候想体验一下Mac的感觉&#xff0c;于是果断下单&#xff0c;又或…

[C语言] 函数详解:库函数与自定义函数

文章目录 函数的概念库函数和自定义函数库函数使用库函数示例常用库函数及头文件 自定义函数自定义函数的基本结构示例&#xff1a;实现两个数的求和函数自定义函数的好处 函数的返回值有返回值的函数无返回值的函数 函数的声明与调用声明函数在另一个文件中调用函数示例&#…