C++ fill函数:使用示例与原理解析

发布时间:2023-05-17

一、填充一个基本数据类型数组

#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
    int arr[5];
    fill(arr, arr+5, 0);
    for(int i=0; i<5; i++)
    {
        cout << arr[i] << " ";
    }
    return 0;
}

fill函数可以将给定区间内的元素全部赋值为指定的值。在上面的示例中,我们定义了一个长度为5的int类型数组arr,然后使用fill函数将其内所有元素都赋值为0。最后,我们使用for循环输出数组中的元素。 需要注意的是,fill函数的第一个参数是要填充的区间的起始地址,而第二个参数是要填充的区间的结束地址(不包括结束地址本身)。因此,在上面的示例中,fill(arr, arr+5, 0)的含义是将arr数组从arr[0]arr[4]这个区间内的元素全部赋值为0。

二、填充一个STL容器

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int main()
{
    vector<int> vec = {1, 2, 3, 4, 5};
    fill(vec.begin() + 1, vec.end() - 1, 0);
    for(auto x : vec)
    {
        cout << x << " ";
    }
    return 0;
}

fill函数同样可以用于STL容器中。在上面的示例中,我们定义了一个长度为5的vector<int>类型容器vec,并将其初始化为{1, 2, 3, 4, 5}。然后,使用fill函数将vec[1]vec[3]这个区间内的元素全部赋值为0,最后使用for循环输出vector中的元素。 需要注意的是,STL容器的begin()函数和end()函数分别返回容器的起始迭代器和结束迭代器,因此fill(vec.begin() + 1, vec.end() - 1, 0)的含义是将vec容器中从第二个元素到倒数第二个元素这个区间内的元素全部赋值为0。

三、填充一个多维数组

#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
    int arr[3][2];
    fill(&arr[0][0], &arr[0][0] + sizeof(arr) / sizeof(int), 0);
    for(int i=0; i<3; i++)
    {
        for(int j=0; j<2; j++)
        {
            cout << arr[i][j] << " ";
        }
        cout << endl;
    }
    return 0;
}

fill函数同样可以用于填充多维数组。在上面的示例中,我们定义了一个3行2列的int类型多维数组arr,并使用fill函数将其全部元素都赋值为0。最后,使用双重for循环输出多维数组中的所有元素。 需要注意的是,对于多维数组,我们需要将起始地址指定为数组的第一个元素的地址,同时需要计算出整个数组的大小,即数组元素个数乘以每个元素的字节数,这里我们使用了sizeof(arr) / sizeof(int)来计算出数组的大小。