memset()是一个用于设置内存块值的函数用<cstring>中
void* memset(void* ptr【指向设置值的内存块指针】,int value【要设置值 是一个整数8位二进制】,size_t num【要设置字节数】)
memset()函数将ptr指向内存块的前num个字节设置为value的值,它返回一个指向ptr的指针
也可以初始化内存块,将其设置为特定值 例如将整形数组的所有元素设置为0,可以使用:
int arr[10]; memset(arr,0,sizeof(arr))
一般char类型准确因为char-8bit-1Byte int-32bit-4Byte所以int会出现存储不准确的情况 如下:
#include <iostream>
#include <vector>
#include <algorithm>
#include<cctype>
using namespace std;
int main()
{
int a[5];
memset(a, 1, sizeof(a));
for (int i = 0; i < 5; i++)cout << a[i] << '\n';
return 0;
}
但是设置0与-1是准确的
swap(&a,&b)函数接受两个参数 先把第一个数存储在临时变量中,把第二个数赋予第一个,在将临时变量赋予第二个。
这个函数可以交换任意类型的变量包括基本类型与自定义类型
#include <iostream>
#include <vector>
#include <algorithm>
#include<cctype>
using namespace std;
int main()
{
int a = 1; int b = 2;
swap(a, b);
cout << a << endl;
cout << b<< endl;
return 0;
}
reverse()是用于反转容器中元素顺序的函数 要用<algorithm>
void reverse(用地址/迭代器:a,a+n])它会将[first,last]范围内的元素按相反顺序重新排序
#include <iostream>
#include <vector>
#include <algorithm>
#include<algorithm>
using namespace std;
int main()
{
vector <int>as = { 1,2,3,4,5 };
reverse(as.begin(), as.end());
for (int a : as) {
cout << a << "";
}
cout << endl;
}
unique()一个去除容器中相邻重复元素的函数,并返回一个指向去重后范围的尾后迭代器。去重后范围保留了第一个出现的元素,后续重复都消失了。
用于文件<algorithm>头文件中
unique(用地址/迭代器:a,a+n])同理[firsr,last]
#include <iostream>
#include <vector>
#include <algorithm>
#include<algorithm>
using namespace std;
int main()
{
vector <int>as = { 1,1,2,2,2,3,3,3,3,4,4,4,5 };
auto it= unique(as.begin(), as.end());
for (int a : as) {
cout << a << " ";
}
cout << endl;
as.erase(it, as.end());
for (int a : as) {
cout << a << " ";
}
cout << endl;
}
这里用unique会返回去重后尾后迭代器,这里用erase相当于把后面堆叠的重复数字删除了
因为用unique只能去除相邻的数字,所以这里要用unique前要先排序