C++ fill()函数解析

2024-03-19 06:38
文章标签 c++ 函数 解析 fill

本文主要是介绍C++ fill()函数解析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C++ fill()函数解析

函数原型

void fill (ForwardIterator first, ForwardIterator last, const T& val);

  • Fill range with value;
  • Assigns val to all the elements in the range [first,last).
    即:按照单元赋值,将一个区间的元素都赋同一个值

函数使用

fill()函数使用时,需要包含头文件.

  1. 例如,使用fill() t填充 数组,fill(array, array+n, value).
    新建fill_array_test.cpp
$ touch fill_array_test.cpp
$ gedit fill_array_test.cpp

编辑文件,内容如下:

#include <iostream>
#include <algorithm>
#include <cstdio>
using namespace std;
int main() {int array[20];//全部填充1fill(array, array + 20, 1);cout <<"全部填充1"<<endl;for(int item = 0; item < sizeof(array)/sizeof(int);item++)cout << array[item]<<"";cout <<endl<<"前10个元素填充2"<<endl;    //前10个元素填充2fill(array, array + 10, 2);for(int item = 0; item < sizeof(array)/sizeof(int);item++)cout << array[item]<<"";  cout <<endl;return 0;
}

编译执行

$ g++ fill_array_test.cpp -o fill_array_test.out
$ ./fill_array_test.out

运行结果:

全部填充1
11111111111111111111
前10个元素填充2
22222222221111111111
  1. 例如,使用fill() t填充vector类型变量,fill(vector.start(), vector.end(), value).
    新建fill_vector_test.cpp
$ touch fill_vector_test.cpp
$ gedit fill_vector_test.cpp

编辑fill_vector_test.cpp

#include <iostream>
#include <algorithm>
#include <vector>
using namespace std;
int main() {vector<int> v{1,1,1,1,1,1,1,1,1,1,1,1,1};cout<<endl;for(int item =0; item<v.size(); item++)cout<<v[item]<<" " ;cout<<endl;fill(v.begin(), v.end(), 2);cout<<endl;for(int item =0; item<v.size(); item++)cout<<v[item]<<" " ;cout<<endl;return 0;
} 

编译执行:

$ g++ fill_vector_test.cpp -o fill_vector_test.out
$ ./fill_vector_test.out

运行结果如下:

1 1 1 1 1 1 1 1 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 2 2 2 

这篇关于C++ fill()函数解析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/825108

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

Java中Redisson 的原理深度解析

《Java中Redisson的原理深度解析》Redisson是一个高性能的Redis客户端,它通过将Redis数据结构映射为Java对象和分布式对象,实现了在Java应用中方便地使用Redis,本文... 目录前言一、核心设计理念二、核心架构与通信层1. 基于 Netty 的异步非阻塞通信2. 编解码器三、

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

一文解析C#中的StringSplitOptions枚举

《一文解析C#中的StringSplitOptions枚举》StringSplitOptions是C#中的一个枚举类型,用于控制string.Split()方法分割字符串时的行为,核心作用是处理分割后... 目录C#的StringSplitOptions枚举1.StringSplitOptions枚举的常用

Python函数作用域与闭包举例深度解析

《Python函数作用域与闭包举例深度解析》Python函数的作用域规则和闭包是编程中的关键概念,它们决定了变量的访问和生命周期,:本文主要介绍Python函数作用域与闭包的相关资料,文中通过代码... 目录1. 基础作用域访问示例1:访问全局变量示例2:访问外层函数变量2. 闭包基础示例3:简单闭包示例4

MyBatis延迟加载与多级缓存全解析

《MyBatis延迟加载与多级缓存全解析》文章介绍MyBatis的延迟加载与多级缓存机制,延迟加载按需加载关联数据提升性能,一级缓存会话级默认开启,二级缓存工厂级支持跨会话共享,增删改操作会清空对应缓... 目录MyBATis延迟加载策略一对多示例一对多示例MyBatis框架的缓存一级缓存二级缓存MyBat

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

Java集合之Iterator迭代器实现代码解析

《Java集合之Iterator迭代器实现代码解析》迭代器Iterator是Java集合框架中的一个核心接口,位于java.util包下,它定义了一种标准的元素访问机制,为各种集合类型提供了一种统一的... 目录一、什么是Iterator二、Iterator的核心方法三、基本使用示例四、Iterator的工