【转】c++ 如何批量初始化数组 fill和fill_n函数的应用

http://blog.csdn.net/sunquana/article/details/9153213

一、 fill和fill_n函数的应用:

    fill函数的作用是:将一个区间的元素都赋予val值。

     函数参数:fill(first,last,val);//first为容器的首迭代器,last为容器的尾迭代器,

替换元素的区间为[first,last),val为将要替换的值。

     eg:
             vector <int> V;
             fill(V.begin(),V.end(),val);

二、fill_n函数的作用是:

给你一个起始点,然后再给你一个数值count和val。把从起始点开始依次赋予 count个元素val的值。

       注意: 不能在没有元素的空容器上调用fill_n函数。

 

例题:给你n个数,然后输入一些操作:start,count,paint。表示从start开始连续填充count个数字,paint为填充的数值。

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
void print(int &elem){cout<<elem<<" ";}
int main()
{
    vector <int> V;
    int n,start,count,paint;
    cin>>n;
    V.resize(n);
    while(cin>>start>>count>>paint)
    {
        fill_n(V.begin()+start-1,count,paint);
        for_each(V.begin(),V.end(),print);
        cout<<endl;
    }
    return 0;
}

其他的一些实例:

   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

三、关于memset()函数:

  这个 函数是按字节覆盖,批量初始化内存空间,下面我们来看一个例子:

//注意移位运算的优先级小于 +
    unsigned int maxn=(1<<31)-1-(1<<7)-(1<<15)-(1<<23);
    int c[2];
    memset(c,0x7f,sizeof(c));
    printf("%0x\n",maxn); //7f7f7f
    printf("%0x\n",c[0]);//7f7f7f

结果都是 :0x7f7f7f由此说明memset的操作方式。

 

我们也可以根据该特性:来定义一个无穷大:

有符号整形的最大值:

max_int= 2147483647,也就是:(1<<31)-1

 而0x7f7f7f=2139062143

eg:因此我们可以这样给数组初始化无穷大:memset(array,0x7f,sizeof(array));

posted @ 2014-07-19 09:02  合唱团abc  阅读(796)  评论(0编辑  收藏  举报