c++ vector 使用find查找指定元素方法

在 C++ 中,std::vector 是一个动态数组,用于存储同类型元素的序列。如果你想在 std::vector 中查找指定元素,可以使用 std::find 算法。std::find 是定义在 <algorithm> 头文件中的标准库函数。

以下是一个示例代码,展示了如何使用 std::findstd::vector 中查找指定元素:

#include<iostream>#include<vector>#include<algorithm>// 包含 std::findintmain(){// 创建一个 vector 并初始化一些元素 std::vector<int> vec ={1,2,3,4,5};// 要查找的元素int target =3;// 使用 std::find 查找元素auto it = std::find(vec.begin(), vec.end(), target);// 检查是否找到元素if(it != vec.end()){ std::cout <<"元素 "<< target <<" 找到在位置: "<< std::distance(vec.begin(), it)<< std::endl;}else{ std::cout <<"元素 "<< target <<" 未找到"<< std::endl;}return0;}

代码说明:

  1. 包含头文件
    • #include <iostream>:用于输入输出操作。
    • #include <vector>:用于使用 std::vector
    • #include <algorithm>:用于使用 std::find
  2. 初始化 std::vector
    • std::vector<int> vec = {1, 2, 3, 4, 5};:创建一个包含 5 个整数的 std::vector
  3. 定义目标元素
    • int target = 3;:定义要查找的目标元素。
  4. 使用 std::find 查找元素
    • auto it = std::find(vec.begin(), vec.end(), target);:调用 std::find,传入 vector 的开始迭代器、结束迭代器和目标值。it 将指向找到的元素或 vec.end()(如果未找到)。
  5. 检查结果
    • if (it != vec.end()):检查迭代器是否等于 vec.end(),如果不等,说明找到了目标元素。
    • std::distance(vec.begin(), it):计算找到元素的位置索引。
    • 如果未找到元素,输出相应的提示信息。

注意事项:

  • std::find 是线性搜索算法,其时间复杂度为 O(n),其中 n 是 vector 的大小。
  • 如果 vector 中包含大量元素,并且查找操作非常频繁,可以考虑使用其他数据结构(如 std::unordered_setstd::set)来提高查找效率。

通过这种方式,你可以在 std::vector 中有效地查找指定元素。

Read more

【 C/C++ 算法】入门动态规划-----一维动态规划基础(以练代学式)

【 C/C++ 算法】入门动态规划-----一维动态规划基础(以练代学式)

每日激励:“不设限和自我肯定的心态:I can do all things。 — Stephen Curry” 绪论 : 本章是动态规划算法的基础入门篇,我将通过三道简单题 + 一道中等难度的一维动态规划题来带你对动态规划有个初认识,并基本了解动态规划的最基本常见的写法,只有将基本写法了解了,对后续的难的题目自然也不会毫无头绪,后续还将持续更新更多相关的动规算法,敬请期待~🙃 ———————— 早关注不迷路,话不多说安全带系好,发车啦(建议电脑观看)。 👻动态规划🌥️ 这里通过大量练习得出下面动态规划做题步骤 简单的说动态规划理解成:某种状态的公式 + 提前求出来值的容器 求出当前位置的值然后放到容器中后后续使用 因为最开始的值一般是会看见的所以就能有初始值,从而启动动态规划 从上中可以主要提炼出: * 状态 * 容器的重要性 * 公式,可以换种说法:状态转移方程 这样严格😈的说:动态规划 = 状态定义 + 状态转移方程 + 初始条件 + 状态存储(容器) 下述步骤是通过写完下述四道题后的总结,所以同样需要道友🗡️大量的练习沉淀最终就能对动态规划的题目

By Ne0inhk
告别付费行情软件:利用 QMT 免费“白嫖”全市场 Tick 级数据 (附 Python 代码)

告别付费行情软件:利用 QMT 免费“白嫖”全市场 Tick 级数据 (附 Python 代码)

前言:作为一名量化开发者,我每年最心疼的支出不是服务器费用,而是数据源费用。Wind 终端一年几万,Tushare 积分也要钱,稍微好点的 Tick 数据源动辄上千。但其实,很多散户手里就握着一把“金钥匙”却不自知——那就是券商免费提供的 QMT。今天,我将教你如何把 QMT 变成一个免费、稳定、实时的行情数据中心。 为什么 QMT 的数据最“香”? 在数据获取这条路上,我们通常有三个选择: 1. 爬虫:容易被封 IP,数据不稳定,且有法律风险。 2. 第三方 API (Tushare/JoinQuant):好用但要钱,免费版有各种限制(如延迟、限流)。 3. 券商 QMT/PTrade:完全免费,速度极快(

By Ne0inhk
蓝桥杯(C 语言 / C++)备考全攻略:3-6 个月从入门到上岸,语法 / 算法 / 真题 + 模板直接用

蓝桥杯(C 语言 / C++)备考全攻略:3-6 个月从入门到上岸,语法 / 算法 / 真题 + 模板直接用

蓝桥杯作为国内极具含金量的编程竞赛,是大学生提升编程能力、丰富简历的重要选择。本文针对 C 语言 / C++ 方向,打造 3-6 个月备考计划,从语法基础到算法进阶,再到真题实战,梳理高频考点并提供可直接复用的代码模板,帮你高效备考、稳步上岸。 一、备考规划:3-6 个月阶段拆解(零基础友好) 1. 基础阶段(1-2 个月):夯实语法与工具         核心目标:掌握 C/C++ 基础语法,熟练使用编译器(Dev-C++/VS Code),能独立编写简单程序。         每日学习时长:2-3 小时。 (1)语法重点(按优先级排序) * 核心语法:变量 / 常量、数据类型(int/long long/double/

By Ne0inhk
【编程语言】理解C/C++当中的指针

【编程语言】理解C/C++当中的指针

指针是C/C++语言中一个非常强大且重要的概念,也是编写高效程序的基础之一。对于没有编程背景的初学者来说,理解指针可能有些难度,但通过本篇文章的介绍,相信你会对指针有一个清晰的认识。本文将从指针的基本概念、作用、代码示例、注意事项等方面,带你一步步了解指针的世界。 什么是指针? 在C/C++中,指针是一种特殊的变量,它存储的是另一个变量的内存地址,而不是一个普通的数值。 * 举例来说,如果我们有一个变量int a = 5;,那么指针变量的值可以是a所在的内存地址。通过指针,我们可以访问或修改这个地址所存储的数值。 简单来说,指针是指向一个内存位置的变量,它可以帮助我们在程序中更灵活地操控数据。 为什么需要指针? 指针的出现主要是为了实现灵活的数据操作和优化内存使用。以下是指针的几个常见用途: 1. 间接访问和修改变量:通过指针,可以在函数中修改传入的变量。 2. 动态内存管理:指针是动态分配内存(如malloc和new)的关键。 3. 提高性能:指针可以直接访问内存,从而提高程序性能。 4. 实现复杂的数据结构:如链表、树和图等数据结构的实现,

By Ne0inhk