C++ fill fill_n 函数

fill 函数和 fill_n 函数在c++ 被称为写入元素算法

在大多数情况下,fill 函数的效率通常比 for 循环更高,尤其是在处理大规模数据时。这是因为 fill 函数通常是用更底层的、高效的方式实现的,可以减少循环开销。

解决memset函数不能对 数组 进行 数字初始化 赋值

然而,具体的效率也取决于编程语言和实现细节。在一些语言中,编译器可能会优化 for 循环,使其效率接近于 fill 函数。

如果关心性能,建议在你的特定环境中进行基准测试,以获得准确的比较结果。

使用 fill 函数更合适的场景包括:

  1. 初始化数组:快速将数组中的所有元素设为相同的值。

  2. 代码简洁:相比 for 循环,fill 函数通常能让代码更简洁和易读。

  3. 性能优化:在需要高效地处理大规模数据时,fill 通常比手动遍历更快。

  4. 不可变操作:在某些函数式编程场景中,使用 fill 可以更好地表达不可变数据操作。

头文件:algorithm
fill_n 函数和 fill 函数不能对空容器进行操作

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

#include<algorithm>
int main()
{
	int a[10];
	int n=10;
	vector<int>b(10);
	fill(a, a+n, val); // 将数组 a 中所有元素赋值为val
	fill(b.begin(), b.end(), val) // 将数组 b 中所有元素赋值为val
}

fill_n函数的作用是:在一个区间内,从给定位置开始赋予 x 个val

#include<algorithm>
int main()
{
	int a[10];
	int n=10;
	vector<int>b(10);
	fill_n(a, x, val); // 将数组 a 的前 x 个元素赋值为val
	fill_n(b.begin(), x, val); // 将数组 b 的前 x 个元素赋值为val
}

可通过back_inserter(vec)函数实现对空容器赋值

back_inserter(vec)函数来自 <iterator>头文件,用于创建一个向量vec的尾插入迭代器。这个迭代器用于在向量的末尾插入新元素,从而动态地调整容器的大小。

#include<algorithm>
#include<iterator>
int mian()
{
	vector<int>a;
	fill_n(back_inserter(a), x, val); // 向容器 a 末尾添加 10 个 val
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值