如果需要对数组中的某些元素赋予相同的值,常见的有两种方法,memset函数和fill函数,二者稍微有一些区别。
memset()
头文件为cstring
函数格式为
memset(数组名, 值, sizeof(数组名) );
memset()只能赋值0或-1,不能赋值其他数字,而且赋值范围是整个数组。这是因为 memset 是按字节赋值,即对每个字节赋同样的值。
比如对int赋值,int 是四个字节,只有两种情况,全零和全一,0000是0的补码,1111是 -1的补码,不能表示其他数值,因此就不能赋其他数值了。示例如下
#include <iostream>
#include <cstring>
using namespace std;
int main() {
int a[5] = {1, 2, 3, 4, 5};
memset(a, -1, sizeof(a));
for(int i = 0; i < 5; i++) {
cout << a[i] << " ";
}
}
输出结果
-1 -1 -1 -1 -1
如果赋值为 1 的话,输出结果
fill()
头文件为algorithm
fill()可以把数组或容器中的某一段区间赋值为某个相同的值。和memset()不同,这里的赋值可以是数组类型对应范围中的任意值。示例如下:
#include <iostream>
#include <algorithm>
using namespace std;
int main() {
int a[5] = {1, 2, 3, 4, 5};
fill(a, a+3, 10);
for(int i = 0; i < 5; i++) {
cout << a[i] << " ";
}
}
输出结果
10 10 10 4 5
那么问题来了,既然fill函数可以赋任意值,那还要memset 干什么,直接fill不就完了呗;其实不然,memset 的执行速度要比 fill 快很多,fill 用时几乎是 memset的两倍左右,详细测试情况可见这篇文章 —>传送门
二者虽然都是赋值,但是各有千秋;
总结来说,使用memset 赋 0 或 -1,fill 赋 其他数字。