目录
memset()是一个用于设置内存块值的函数。它的原型定义在<cstring>头文件中,函数的声明如下:
void* memset(void* ptr,int value,size_t num);//指针 值 重置的大小
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(T&a,T&b)函数接收两个参数:
1.a:要交换值的第一个变量的引用。
2.b:要交换值的第二个变量的引用。
swap()函数通过将第一个变量的值存储到临时变量中,然后将第二个变量的值赋给第一个变量,最后将临时变量的值赋给第二个变量,实现两个变量值的交换。
swap()函数可以用于交换任意类型的的变量,包括基本类型(如整数、浮点数等)和自定义类型(如结构体、类对象等)。
reverse()是一个用于反转容器中元素顺序的函数。
它的原型定义在<algorithm>头文件中,函数声明如下:
template<class BidirIt>
void reverse(BidirIt first,BidirIt last);
1.first:指向容器中要反转的第一个元素的迭代器
2.last:指向容器中要反转的最后一个元素的下一个位置的迭代器。
reverse()函数将[firsrt,last)范围内的元素按相反的顺序重新排序。
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()是一个用于去除容器中相邻重复元素的函数。原型定义在<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;
}