这里在网上找到了一个归纳的非常好的总结
fill函数,fill与memset函数的区别
- memset函数
-
- 按照字节填充某字符
- 在头文件
<string。h>中
- 因为memset函数按照字节填充,所以一般memset只能用来填充char型数组,(因为只有char型占一个字节)如果填充int型数组,除了0和-1,其他的不能。因为只有00000000 = 0,-1同理,如果我们把每一位都填充“1”,会导致变成填充入“11111111”
- 例如
int a[20];
memset(a, 0, sizeof a);
- fill-n 函数
fill_n函数的作用是:给你一个起始点,然后再给你一个数值count和val。把从起始点开始依次赋予count个元素val的值。
注意: 不能在没有元素的空容器上调用fill_n函数
例题:给你n个数,然后输入一些操作:start,count,paint。表示从start开始连续填充count个数字,paint为填充的数值。
- fill函数
-
- 按照单元赋值,将一个区间的元素都赋同一个值
- 在头文件
<algorithm>
里面 - fill函数可以赋值任何,而且使用方法特别简便
- fill(arr, arr + n, 要填入的内容)
例如:
int arr[10];
fill(arr,
arr + 10, 2)
- vector
vector<int> myvector (8,10); // myvector: 10 10 10 10 10 10 10 10
fill_n (myvector.begin(),4,20); // myvector: 20 20 20 20 10 10 10 10
fill_n (myvector.begin()+3,3,33); // myvector: 20 20 20 33 33 33 10 10
vector<int> v{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
fill(v.begin(), v.end(), -1);
时间: 2024-10-19 17:56:38