C++ Primer 第五版 中文版 阅读笔记 + 个人思考

C++ Primer 第五版 中文版 阅读笔记 + 个人思考

  • 第 10 章 泛型算法
    • 10.1 概述
    • 练习10.1
    • 练习10.2

第 10 章 泛型算法

泛型的体现:容器类型(包括内置数组),元素类型,元素操作方法。
顺序容器定义的操作:insert,erase,back,front,empty,begin_iterator,end_next_iterator。

10.1 概述

算法在容器泛型上的实现:遍历由两个迭代器指定的一个元素范围进行操作。
算法依赖于元素类型支持的操作,允许我们自定义操作代替默认的运算符。

代码演示:find操作的是迭代器,可以用于任何容器。

#include <iostream>  
#include <vector>  
#include <list>  
#include <set>  
#include <map>  
#include <algorithm>  

int main() {
    // 1. 在一个向量中查找元素  
    std::vector<int> vec = { 1, 2, 3, 4, 5 };
    int valToFind = 3;
    if (std::find(vec.begin(), vec.end(), valToFind) != vec.end()) 
    {
        std::cout << "Found " << valToFind << " in vector." << std::endl;
    }
    else 
    {
        std::cout << valToFind << " not found in vector." << std::endl;
    }

    // 2. 在一个列表中查找元素  
    std::list<int> lst = { 1, 2, 3, 4, 5 };
    valToFind = 4;
    if (std::find(lst.begin(), lst.end(), valToFind) != lst.end()) 
    {
        std::cout << "Found " << valToFind << " in list." << std::endl;
    }
    else 
    {
        std::cout << valToFind << " not found in list." << std::endl;
    }

    // 3. 在一个集合中查找元素(集合中的元素是唯一的,所以只会找到一个匹配项)  
    std::set<int> s = { 1, 2, 3, 4, 5 };
    valToFind = 3;
    if (std::find(s.begin(), s.end(), valToFind) != s.end()) 
    {
        std::cout << "Found " << valToFind << " in set." << std::endl;
    }
    else 
    {
        std::cout << valToFind << " not found in set." << std::endl;
    }

    // 4. 在一个映射中查找元素(键值对)  
    std::map<int, std::string> m = { {1, "one"}, {2, "two"}, {3, "three"} };
    
    auto mit = std::find(m.begin(), m.end(), std::make_pair(2, "two"));
    if (mit != m.end()) 
    {
        std::cout << "Found " << mit->first << " in map with value: " << mit->second << std::endl;
    }
    else 
    {
        std::cout << valToFind << " not found in map." << std::endl;
    }

    return 0;
}

运行结果:
运行结果

代码演示:find函数用于内置数组。

#include <iostream>  
#include <algorithm>

int main() 
{
    int array[5] = { 1,2,3,4,5 };
    int val = 4;
    if (std::end(array) != std::find(std::begin(array), std::end(array), val))
    {
        std::cout << val << " is present" << std::endl;
    }
    else
    {
        std::cout << val << " is not present" << std::endl;
    }

    if (array + 2 != std::find(array, array + 2, val))
    {
        std::cout << val << " is present" << std::endl;
    }
    else
    {
        std::cout << val << " is not present" << std::endl;
    }

    return 0;
}

运行结果:
运行结果

算法运行于迭代器之上,不会修改容器大小。
存在插入器 inserter :赋值时,在底层容器上执行插入操作。

练习10.1

代码演示:

#include <iostream>  
#include <algorithm>
#include <vector>

int main() 
{
    std::vector<int> vi = { 1,2,3,3,3,4,5 };
    int val = 3;
    std::cout << val << " count: " << std::count(vi.begin(), vi.end(), val) << std::endl;

    val = 2;
    std::cout << val << " count: " << std::count(vi.begin(), vi.end(), val) << std::endl;

    return 0;
}

运行结果:
运行结果

练习10.2

代码演示:

#include <iostream>  
#include <algorithm>
#include <vector>
#include <string>

int main() 
{
    std::vector < std::string > vs = { "hello","hello","hello","world","world" };
    std::string val = "hello";

    std::cout << val << " count: " << std::count(vs.begin(), vs.end(), val) << std::endl;

    val = "world";
    std::cout << val << " count: " << std::count(vs.begin(), vs.end(), val) << std::endl;

    return 0;
}

运行结果:
运行结果

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Android-多线程

线程是进程中可独立执行的最小单位&#xff0c;也是 CPU 资源&#xff08;时间片&#xff09;分配的基本单位&#xff0c;同一个进程中的线程可以共享进程中的资源&#xff0c;如内存空间和文件句柄。线程有一些基本的属性&#xff0c;如id、name、以及priority。 id&#xff1…

API调试怎么做?Apipost快速上手

前言 Apipost是一款支持 RESTful API、SOAP API、GraphQL API等多种API类型&#xff0c;支持 HTTPS、WebSocket、gRPC多种通信协议的API调试工具。除此之外&#xff0c;Apipost 还提供了自动化测试、团队协作、等多种功能。这些丰富的功能简化了工作流程&#xff0c;提高了研发…

antv/x6_2.0学习使用(四、边)

一、添加边 节点和边都有共同的基类 Cell&#xff0c;除了从 Cell 继承属性外&#xff0c;还支持以下选项。 属性名类型默认值描述sourceTerminalData-源节点或起始点targetTerminalData-目标节点或目标点verticesPoint.PointLike[]-路径点routerRouterData-路由connectorCon…

网络流量分析与故障分析

1.网络流量实时分析 网络监控 也snmp协议 交换机和服务器打开 snmp就ok了 MRTG或者是prgt 用于对网络流量进行实时监测&#xff0c;可以及时了解服务器和交换机的流量&#xff0c;防止因流量过大而导致服务器瘫痪或网络拥塞。 原理 通过snmp监控 是一个…

MES/MOM标准之ISA-95基础内容介绍

ISA-95 简称S95&#xff0c;也有称作SP95。ISA-95 是企业系统与控制系统集成国际标准&#xff0c;由国际自动化学会(ISA&#xff0c;International Society of Automation) 在1995年投票通过。该标准的开发过程是由 ANSI(美国国家标准协会) 监督并保证其过程是正确的。ISA-95不…

acwing 并查集

目录 并查集的路径压缩两种方法法一法二 AcWing 240. 食物链AcWing 837. 连通块中点的数量示例并查集自写并查集 并查集的路径压缩两种方法 法一 沿着路径查询过程中&#xff0c;将非根节点的值都更新为最后查到的根节点 int find(int x) {if (p[x] ! x) p[x] find(p[x]);r…

爬取去哪网旅游攻略信息

代码展现&#xff1a; import requests import parsel import csv import time f open(旅游去哪攻略.csv,modea,encodingutf-8,newline) csv_writer csv.writer(f) csv_writer.writerow([标题,浏览量,日期,天数,人物,人均价格,玩法]) for page in range(1,5):url fhttps://…

整理的Binder、DMS、Handler、PMS、WMS等流程图

AMS&#xff1a; Binder&#xff1a; Handler&#xff1a; PMS&#xff1a; starActivity&#xff1a; WMS&#xff1a; 系统启动&#xff1a;

kdump安装及调试策略

本文基于redhat系的操作系统&#xff0c;debian系不太一样&#xff0c;仅提供参考 1.kdump的部署 注&#xff1a;一般很多操作系统在安装时可默认启动kdump。 &#xff08;1&#xff09;需要的包 yum install kexec-tools crash kernel-debuginfo &#xff08;2&#xff0…

python画房子

前言 今天&#xff0c;我们来用Python画房子。 一、第一种 第一种比较简单。 代码&#xff1a; import turtle as t import timedef go(x, y):t.penup()t.goto(x, y)t.pendown() def rangle(h,w):t.left(180)t.forward(h)t.right(90)t.forward(w)t.left(-90)t.forward(h) de…

《A++ 敏捷开发》- 3 克服拖延症

技术总监问&#xff1a;现在我遇到最大的难题就是如何提升下面技术人员的能力&#xff0c;如果他们全都是高手&#xff0c;我就很轻松了&#xff0c;但实际上高手最多只有 1/3&#xff0c;其他都是中低水平。你接触过这么多软件开发团队&#xff0c;有什么好方案&#xff1f; 我…

【影刀RPA_如何使用影刀的企业微信指令?】

思路&#xff1a;先用python代码过一遍&#xff0c;再将必要参数填到指令里面。 第一步&#xff1a; 1、在企业微信后台新建应用&#xff0c;设置消息接收地址&#xff08;需要服务器的公网ip地址&#xff09;&#xff0c;进行签名验证。然后&#xff0c;从浏览器中查询ip地址…

贯穿设计模式-中介模式+模版模式

样例代码 涉及到的项目样例代码均可以从https://github.com/WeiXiao-Hyy/Design-Patterns.git获取 需求 购买商品时会存在着朋友代付的场景&#xff0c;可以抽象为购买者&#xff0c;支付者和中介者之间的关系 -> 中介者模式下单&#xff0c;支付&#xff0c;发货&#xff0…

正则表达式Regex

是什么&#xff1a;一句话&#xff0c;正则表达式是对字符串执行模式匹配的技术。 从一段字符串中提取出所有英文单词、数字、字母和数字。 如果采用传统方法&#xff1a;将字符串的所有字符分割成单个&#xff0c;根据ASCII码判断&#xff0c;在一定范围内就是字母&#xff…

C++指针详解

定义&#xff1a; 指针是一个整数&#xff0c;一种存储内存地址的数字 内存就像一条线性的线&#xff0c;在这条街上的每一个房子都有一个号码和地址类似比喻成电脑&#xff0c;这条街上每一个房子的地址 是一个字节我们需要能够准确找到这些地址的方法&#xff0c;用来读写操…

中小型家具制造业使用制造管理MES系统应该注意什么?

随着人们生活水平变高&#xff0c;人们对家具的要求也在提高。为了应对越来越高的要求&#xff0c;企业开始寻找更有效的方法&#xff0c;其中就包括mes系统&#xff0c;那么中小型家具企业在使用mes的过程中应该注意什么呢&#xff1f; 第一&#xff0c;要考虑选择什么样的mes…

kubernetes Service 详解

写在前面&#xff1a;如有问题&#xff0c;以你为准&#xff0c; 目前24年应届生&#xff0c;各位大佬轻喷&#xff0c;部分资料与图片来自网络 内容较长&#xff0c;页面右上角目录方便跳转 Service 介绍 架构 在kubernetes中&#xff0c;Pod是应用程序的载体&#xff0c;…

【Azure 架构师学习笔记】- Azure Databricks (5) - Unity Catalog 简介

本文属于【Azure 架构师学习笔记】系列。 本文属于【Azure Databricks】系列。 接上文 【Azure 架构师学习笔记】- Azure Databricks (4) - 使用Azure Key Vault 管理ADB Secret 前言 DataBricks Unity Catalog&#xff08;UC&#xff09;是一个统一的对数据资产治理的解决方案…

[蓝桥杯学习] 树状数组的二分

要解决这个问题&#xff0c;插入和删除可以用STL实现&#xff0c;2操作如果用树状数组实现的话&#xff0c;将数的值作为树状数组的下标&#xff0c;即值域。 树状数组有两种操作&#xff0c;一个是更新某点的值&#xff0c;另一个是求区间和。 mid (lr)/2 &#xff0c;求和 …

Vmware安装Windows11系统及下载MySQL步骤(超详细)

一、创建虚拟机 ①选择自定义 ②直接点击下一步 ③选择Windows 11 x64 ④命名虚拟机以及选择路径 ⑤新版本的虚拟机需要加密&#xff08;密码需要8个字符以上&#xff09; ⑥选择UEFI ⑦处理器配置&#xff08;根据自己的需求&#xff09; ⑧设置虚拟机的内存 ⑨选择不使用网络…