c++一些使用频率较高的库函数

发布时间:2024年01月13日

目录

memset()

memset()接受三个参数:

注意

swap()

reverse()

reverse函数接收两个参数:

reverse()反转整形向量元素顺序示例

unique()

接收两个参数

代码例子-相邻


memset()

memset()是一个用于设置内存块值的函数。它的原型定义在<cstring>头文件中,函数的声明如下:

void* memset(void* ptr,int value,size_t num);//指针 值 重置的大小

memset()接受三个参数:

1.ptr:指向要设置值的内存块的指针

2.value:要设置的值,通常是一个整数(八位二进制数)

3.num:要设置的字节 Byte = 8bit

memset()函数将ptr指向的前num个字节设置为value值。它返回一个指向ptr的指针。

memset()函数通常用于初始化内存块,将其设置为特定的值。

例如如果将一个整形数组的所有元素设置为0,可以使用memset()函数如下:

int arr[10];memset(arr,0,sizeof(arr));

注意

memset()函数对于非字符型的数组可能会产生未定义的行为。

??????????????? char-8bit-1Byte

??????????????? int-32bit-4Byte

在处理非字符型的数组时,更好使用c++中的其他方法,如循环遍历来初始化数组,memset会将每个Byte设置为value。

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()函数将[firsrt,last)范围内的元素按相反的顺序重新排序。

reverse()函数可用于反转各种类型的容器,包括数组、向量、链表等。

reverse()反转整形向量元素顺序示例

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
	vector<int>vec = { 1,2,3,4,5 };
	reverse(vec.begin(), vec.end());
	for (int num : vec)
	{
		cout << num << ' ';
	}
	system("pause");
	return 0;
}

结果:5 4 3 2 1

需要注意的是:reverse()函数只能用于支持双向迭代器的容器,因为它需要能够向前和向后遍历容器中的元素。对于只支持单向迭代器的容器(如前向链表),无法使用reverse()函数进行反转。

unique()

unique()是一个用于去除容器中相邻重复元素的函数。原型定义在<algorithm>

接收两个参数

1、first指向容器中要去重的第一个元素的迭代器

2、last指向容器中要去重的最后一个元素的下一个位置的迭代器

因为只能去除相邻相同的元素,所以去重前要先排序

代码例子-相邻

#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main()
{
	int a[] = { 3,1,1,2,2,3 };
    sort(a,a+5);
	int n = unique(a, a + 5) - a;
	for (int i = 0;i<n;i++)
	{
		cout << a[i] << ' ';
	}
	system("pause");
	return 0;
}

文章来源:https://blog.csdn.net/weixin_63201442/article/details/135490297
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。