当前位置: 首页 > news >正文

std::iota(C++)

std::iota

  • 1. 概述
  • 2. 函数原型
  • 3. 使用示例
    • 示例 1:填充 vector<int>
    • 示例 2:从非零起始值开始
  • 4. 应用场景
  • 5. 注意事项
  • 6. 与其它算法比较
  • 小结

1. 概述

  • std::iota 定义在头文件 中,C++11 起引入。

  • 它用于向前迭代器区间依次填入连续递增的数值。

  • 常用于一次性将容器初始化为 0,1,2,… 或从任意起始值开始的连续整数序列。

2. 函数原型

namespace std {template< class ForwardIt, class T >void iota(ForwardIt first, ForwardIt last, T value);
}
模板参数说明
ForwardIt必须满足 ForwardIterator,即支持多次遍历的迭代器类型
T可拷贝、可递增(使用 ++ 运算符)的值类型
  • 参数

    • first, last:给定的迭代器区间 [first, last)。

    • value:起始值,第一个位置赋 value,之后不断 ++value。

  • 返回类型

    • void,不返回任何值。
  • 时间复杂度

    • 线性:执行次数等于区间长度 N = std::distance(first, last),共做 N 次赋值操作。

3. 使用示例

示例 1:填充 vector

#include <iostream>
#include <vector>
#include <numeric>   // for std::iotaint main() {int N = 10;std::vector<int> v(N);std::iota(v.begin(), v.end(), 0);  // v = {0,1,2,...,9}for (int x : v) std::cout << x << ' ';// 输出:0 1 2 3 4 5 6 7 8 9
}

示例 2:从非零起始值开始

#include <deque>
#include <numeric>std::deque<long> dq(5);
std::iota(dq.begin(), dq.end(), 100L);  
// dq = {100,101,102,103,104}

4. 应用场景

  • 容器初始化
    快速生成固定模式的数据:索引序列、ID 列表、测试用例等。

  • 排列生成
    先 iota 填充再对区间 shuffle,可快速生成随机排列。

  • 与算法结合
    与 std::sort、std::unique 等配合,用于排序检测、差分计算等场景。

5. 注意事项

  • 溢出风险
    如果 T 是整型且区间过长,连续递增可能导致溢出。建议保证 value + (last-first -1) 在类型范围内。

  • 迭代器要求
    必须至少满足 ForwardIterator:随机访问迭代器、单向链表迭代器等都可以。

  • 类型转换
    如果 T 与容器元素类型不一致,会发生隐式转换;最好保持一致或显式转换以避免警告。

  • C++20 Ranges
    C++20 引入了 std::views::iota,可生成惰性(lazy)序列视图:

    #include <ranges>
    auto view = std::views::iota(5, 10);  // 表示 5,6,7,8,9
    

6. 与其它算法比较

算法优势劣势
std::iota专门生成递增序列、语义直观只能递增 ++,不支持其它模式
std::generate可自定义生成逻辑(函数/lambda)代码相对冗长
std::generate_n同上,可限制生成次数同上

小结

  • std::iota 是填充递增序列的专用工具,使用简单、效率高。

  • 在需要连续整数、索引填充、快速生成排列等场景时,它是首选。

  • 仅需包含 ,并保证区间非空且值类型无溢出即可。

相关文章:

  • 软件工程之形式化说明技术深度解析
  • 对 Kotlin 中的 data 关键字的理解,相比于普通类有哪些特点?
  • Kotlin Coroutine与Retrofit网络层构建指南
  • C++ - 类和对象 #日期类的实现
  • Go主要里程碑版本及其新增特性
  • 微软推动智能体协同运作:支持 A2A、MCP 协议
  • 学习c语言的链表的概念、操作(另一篇链表的笔记在其他的栏目先看这个)
  • Java网络编程:深入剖析UDP数据报的奥秘与实践
  • 【Linux系统】第三节—权限
  • 使用 React 实现语音识别并转换功能
  • STM32教程:串口USART使用(基于STM32F103C8T6最小系统板标准库开发)*详细教程*
  • MCP 智能体性能监控、弹性扩展与大规模调度系统设计
  • 【Qt开发】Qt开发的认识
  • CF每日5题
  • 网络接入服务商查询
  • 数据结构-堆排序
  • Linux的基础开发工具
  • C++ - 输入输出
  • 网工实验——OSPF配置
  • 面试问题总结(回忆版)
  • 比尔·盖茨:未来20年通过盖茨基金会捐出几乎全部财富,2045年底基金会停止运营
  • 追光|铁皮房、土操场,这有一座“筑梦”摔跤馆
  • 陕西澄城打造“中国樱桃第一县”:从黄土高原走向海外,年产值超30亿
  • 男子煎服15克山豆根中毒送医,医生:不能盲目相信偏方
  • 李云泽:支持小微企业、民企融资一揽子政策将从增供给、降成本、提效率、优环境4个方面发力
  • 李云泽:小微企业融资协调工作机制已发放贷款12.6万亿元