首页 > 代码库 > fill,fill-n,memset的区别

fill,fill-n,memset的区别

这里在网上找到了一个归纳的非常好的总结

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);

 

fill,fill-n,memset的区别