C++ STL for_each_n用法和实现

一:功能

        遍历前n个元素

二:用法

#include <vector>
#include <algorithm>
#include <string>
#include <iostream>
#include <execution>
#include <syncstream>constexpr inline size_t MAIN_SEATS = 8;
constexpr inline size_t PAGE_SIZE = 5;struct Player {int score = 0;std::string display_name;
};std::vector<Player> get_rankings() {return {{20, "Player 1"}, {21, "Player 2"}, {23, "Player 3"}, {19, "Player 4"}, {5, "Player 5"},{18, "Player 6"}, {17, "Player 7"}, {25, "Player 8"}, {24, "Player 9"}, {3, "Player 10"},};
}void send_invitation_to_main_tournament(const Player& player) {std::osyncstream(std::cout) << "Inviting " << player.display_name << " to the main tournament.\n";
}void store_final_score(int page, const std::string& name, int score) {std::osyncstream(std::cout) << "Appending to page " << page << " : " << name << " scored " << score << ".\n";
}int main() {std::vector<Player> final_ranking = get_rankings();std::ranges::sort(final_ranking, std::greater<>(), &Player::score);std::for_each_n(std::execution::par_unseq, final_ranking.begin(), std::min(MAIN_SEATS, final_ranking.size()),send_invitation_to_main_tournament);auto it = final_ranking.begin();uint32_t page = 0;while (it != final_ranking.end()) {size_t cnt = std::min(PAGE_SIZE, size_t(final_ranking.end() - it));std::for_each_n(it, cnt, [page](const Player& p) {store_final_score(page, p.display_name, p.score);});page++;it += cnt;}
}

三:实现

#include <algorithm>
#include <iostream>
#include <vector>template<class InputIt, class Size, class UnaryFunction>
InputIt my_for_each_n(InputIt first, Size n, UnaryFunction f)
{for (Size i = 0; i < n; ++first, (void) ++i) {f(*first);}return first;
}int main()
{std::vector<int> ns{1, 2, 3, 4, 5};for (auto n: ns) std::cout << n << ", ";std::cout << '\n';my_for_each_n(ns.begin(), 3, [](auto& n){ return n; });for (auto n: ns) std::cout << n << ", ";std::cout << '\n';
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/869652.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

存储过程的使用场景

存储过程&#xff08;Stored Procedure&#xff09;在数据库管理系统中具有广泛的应用场景。它们可以帮助提高性能、增强安全性、简化复杂操作&#xff0c;并提供更好的代码重用性和维护性。以下是一些常见的存储过程使用场景&#xff1a; 1. 数据验证 存储过程可以用于数据验…

高考后的IT专业启航:暑期预习指南与学习路线图

文章目录 每日一句正能量前言&#xff1a;启航IT世界&#xff0c;高考后的暑期学习之旅基础课程预习指南基础课程预习指南&#xff1a;构建你的IT知识大厦引言一、计算机科学导论二、编程语言入门三、操作系统基础四、数据结构与算法五、网络基础六、数据库原理结语 技术学习路…

02STM32软件安装新建工程

STM32软件安装&新建工程 1.软件安装&#xff1a;1.1Keil5 MDK安装1.2安装器件支持包离线安装支持包在线安装支持包 1.3软件注册&#xff1a;1.4安装驱动STLINK驱动JLink驱动在此文件夹下USB转串口 2.新建工程2.1STM32开发方式&#xff1a;1.寄存器2.标准库3.HAL库 固件库压…

Nginx访问日志按天拆分

使用 logrotate 来实现 如果系统没有安装logrotate 可以使用 sudo yum install logrotate -y 进行安装 配置 logrotate 接下来我们就来配置 nginx 切割的配置文件&#xff0c;我的 nginx 日志路径在/var/log/nginx 我们在 /etc/logrotate.d/ 目录下新建一个 nginx 的文件…

C++ Primer 总结索引 | 第十六章:模板与泛型编程

1、面向对象编程&#xff08;OOP&#xff09;和泛型编程 都能处理在编写程序时 不知道类型的情况。不同之处在于&#xff1a;OOP 能处理类型 在程序运行之前都未知的情况&#xff1b;而在泛型编程中&#xff0c;在编译时就能获知类型了 2、容器、迭代器 和 算法 都是泛型编程的…

【热梗案例】知识点阶段性综合汇总

文章目录 渲染对象、实现统计功能实现删除功能设置发布按钮实现发布按钮的提交功能 直接用CSS的模板&#xff0c;模板代码如下&#xff1a; <template><view class"title">近期热梗</view><view class"out"> <view class&qu…

全面解析BPMN、CMMN、DMN与XML

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 &#x1f38f;&#xff1a;你只管努力&#xff0c;剩下的交给时间 &#x1f3e0; &#xff1a;小破站 全面解析BPMN、CMMN、DMN与XML 前言BPMN&#xff08;业务流程模型与标记法&#xff09;定义与用途…

206. 反转链表 (Swift 版本)

题目 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 解题 /*** Definition for singly-linked list.* public class ListNode {* public var val: Int* public var next: ListNode?* public init() { self.val 0; self.…

[数据结构] 基于插入的排序 插入排序希尔排序

标题&#xff1a;[数据结构] 排序#插入排序&希尔排序 水墨不写bug 目录 &#xff08;一&#xff09;插入排序 实现思路&#xff1a; 插入排序实现&#xff1a; &#xff08;二&#xff09;希尔排序 希尔排序的基本思想&#xff1a; 希尔排序的实现&#xff1a; 正…

MybatisPlus 多数据源 @DS 选择深入源码理解原理

文章目录 MybatisPlus 多数据源 DS 选择深入源码理解原理 MybatisPlus 多数据源 DS 选择深入源码理解原理 数据源的选择&#xff0c;拦截器为DynamicDataSourceAnnotationInterceptor 这里利用了一个MethodInterceptor接口&#xff0c;我们看看&#xff0c;我们可以看到这个包…

防御笔记第四天(持续更新)

1.状态检测技术 检测数据包是否符合协议的逻辑顺序&#xff1b;检查是否是逻辑上的首包&#xff0c;只有首包才会创建会话表。 状态检测机制可以选择关闭或则开启 [USG6000V1]firewall session link-state tcp ? check Indicate link state check [USG6000V1]firewall ses…

CLion学习笔记-cmake编译和多main函数编译

这里就不讲怎么配置clion了 项目名字 pcl_kdtree_search 1.新建一个工程名字自己取&#xff0c;我这里用自己学习pcl的&#xff0c;加一个main函数&#xff0c;这个时候Cmake里边就是这样的。 #声明要求的cmake最低版本 cmake_minimum_required(VERSION 3.19) #声明一个工程…

MongoDB 全文检索

MongoDB 全文检索 MongoDB 是一个流行的 NoSQL 数据库&#xff0c;以其灵活的数据模型和强大的查询语言而闻名。在 MongoDB 中&#xff0c;全文检索是一种功能&#xff0c;允许用户对存储在数据库中的文本数据进行复杂的搜索。全文检索对于构建搜索引擎、内容推荐系统和文本分…

【SQL】MySQL 中主要的锁类型

在MySQL中&#xff0c;主要有以下几种锁类型&#xff0c;每种锁都有不同的特点和使用场景&#xff1a; 1. 共享锁 (Shared Lock, S Lock) 共享锁是一种读取锁&#xff0c;也称为S锁。多个事务可以同时持有共享锁&#xff0c;并且不会阻塞其他事务获取共享锁&#xff0c;但会阻…

消息称台积电下周开始试产 2nm 芯片,有望率先用于苹果 iPhone 17

消息称台积电下周开始试产 2nm 芯片&#xff0c;有望率先用于苹果 iPhone 17 &#x1f4a1;&#x1f4f1; 大家好&#xff0c;我是猫头虎&#xff0c;科技自媒体博主 &#x1f431;&#x1f42f;&#xff0c;带你洞察科技世界的每一个细节&#xff01;&#x1f525; 关于猫头…

sklearn(Python机器学习库)介绍

0 引言 Sklearn (全称 Scikit-Learn)是基于Python 编程语言的免费软件机器学习库。 Scikit-learn主要是用Python编写的,它建立在 NumPy, SciPy, Pandas 和 Matplotlib 之上,里面API 的设计非常好,所有对象的接口简单,很适合新手上路。 Scikit-learn与许多其他Python库很好地…

Linux学习笔记(三)文件权限

一、权限的分类 Linux权限分为r(读取)、w(写入)、x(执行)。我们在终端执行ls -l命令查看文件详细信息显示如下: [root@srv sun]# ls -l 总用量 0 drwxr-xr-x. 2 sun root 6 7月 5 14:05 公共 drwxr-xr-x. 2 sun root 6 7月 5 14:05 模板 drwxr-xr-x. 2 sun root…

netty udp创建服务端+客户端

一.udp创建服务端 /*** udp 服务器 */ Slf4j Component public class UdpServer {/*** 创建服务端*/Asyncpublic void bind(int port) {EventLoopGroup group new NioEventLoopGroup();try {Bootstrap b new Bootstrap();b.group(group).channel(NioDatagramChannel.class).…

vue 导出excel乱码问题

今天做一个导出excel的功能&#xff0c;导出文件显示乱码&#xff0c;分析接口无问题&#xff0c;后修改如下&#xff1a; 1.接口的response类型&#xff1a;类型设置为blob // 导出信息 export const exportInfo (data: any, config { timeout: 6000, responseType: "…

MAT(Eclipse Memory Analyzer) Windows安装

MAT&#xff08;Eclipse Memory Analyzer&#xff09; Windows安装 MAT&#xff08;Eclipse Memory Analyzer&#xff09;是一个Java的内存分析工具 MAT下载地址 安装完成之后的目录机构 如若出现java版本过低的解决办法 在配置文件MemoryAnalyzer.ini中添加指定Java的版本…