C++ fill()和fill_n()函数用法

fill 和fill_n函数是C++ Primer第十二章泛型算法部分内容,并把它们称为生成和变异算法,也就是说这两个函数只能对输入范围内已存在的元素进行操作。如果试图对空容器进行fill_n操作,会导致严重的运行错误,所以在对元素进行写入操作时要检查目标的大小是否足以存储要写入的元素。(copy)

fill函数的作用:将一个区间的元素都赋予val值。
函数参数 :fill(vec.begin(), vec.end(), val); val为将要替换的值。

fill_n函数的作用:参数包括 : 一个迭代器,一个计数器以及一个值。该函数从迭代器指向的元素开始,将指定数量的元素设置为给定的值。

fill_n(vec.begin(),10,val);

注意: 不能在没有元素的空容器上调用fill_n函数,但是可以通过下面的方法改进。
fill_n(vec.begin(),10,val);
为了保证算法有足够的元素存储输出数据,我们使用“插入迭代器”(insert iterator),插入迭代器是可以给基础容器添加元素的迭代器。

请看例子:

        bool p[501];
        fill(p+1,p+500,0);
        int p[501];
        fill(p+1,p+500,0);
#include<bits/stdc++.h>
#define mem(a,b) memset(a,b,sizeof(a))
typedef long long ll;
using namespace std;
int main()
{
   

    char p[501];
    fill(p+1,p+500,'*');
    for(int i=0;i<500;i++)
        cout<<p[i]<<endl;
    return 0;
}