尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

6.25小学期CPP基础语法记录:反转、字符串查找、稳定sort

6.25小学期CPP基础语法记录:反转、字符串查找、稳定sort
📅 发布时间:2026/7/2 0:40:15

reverse函数

在 C++ 中,reverse是一个非常常用的 STL 算法,用于就地反转序列中的元素顺序。它定义在<algorithm>头文件中。

🧩 函数定义

template <class BidirectionalIterator> void reverse(BidirectionalIterator first, BidirectionalIterator last);
  • 参数说明:
    • first:反转范围的起始迭代器(包含)。
    • last:反转范围的终止迭代器(不包含)。
  • 返回值:
    • 无(void),它是就地修改,直接在原容器上改变顺序。
  • 迭代器要求:
    • 必须是双向迭代器(如vector,list,deque都支持;forward_list不支持)。

✅ 示例

1. 反转vector<int>

#include <iostream> #include <vector> #include <algorithm> // for reverse int main() { std::vector<int> v = {1, 2, 3, 4, 5}; std::reverse(v.begin(), v.end()); for (int i : v) std::cout << i << " "; return 0; }

输出:

5 4 3 2 1

2. 反转string(也支持,因为string::iterator是双向的)

#include <iostream> #include <string> #include <algorithm> int main() { std::string s = "abcdef"; std::reverse(s.begin(), s.end()); std::cout << s; // 输出: fedcba return 0; }

3. 局部反转

cpp复制编辑std::vector<int> v = {10, 20, 30, 40, 50, 60}; // 只反转中间部分 [1, 4) std::reverse(v.begin() + 1, v.begin() + 4); // -> 10, 40, 30, 20, 50, 60

🚀 reverse 的底层实现原理

使用的是双向迭代器,通过交换front和back元素来实现反转。

伪代码:

while (first != last && first != --last) { swap(*first, *last); ++first; }

🎯 时间复杂度与空间复杂度

  • 时间复杂度:O(n)
  • 空间复杂度:O(1)(原地操作,不使用额外空间)

🎓 举一反三

  • std::reverse_copy(first, last, dest):把反转结果复制到另一个位置,不影响原数据。
std::vector<int> v = {1,2,3,4,5}; std::vector<int> res(5); std::reverse_copy(v.begin(), v.end(), res.begin()); // res = 5,4,3,2,1
  • 如果你想自己实现一个reverse函数,可以练习写模板函数操作双向迭代器。

🔍 string::find函数

C++ 中的string::find是处理字符串查找的核心函数,常用于查找某个子串或字符第一次出现的位置。下面我们详细分析它的用法、变体、返回值,再拓展介绍其他常见的字符串查找函数,比如rfind、find_first_of、find_last_of、find_first_not_of等。

🔍 一、string::find基本用法

size_t find(const string& str, size_t pos = 0) const; size_t find(const char* s, size_t pos = 0) const; size_t find(const char* s, size_t pos, size_t n) const; size_t find(char c, size_t pos = 0) const;

✅ 参数说明:

  • str/s/c: 要查找的目标字符串/字符。
  • pos: 从原字符串的哪个位置开始查找(默认为 0)。

✅ 返回值:

  • 成功:返回目标第一次出现的位置(类型为size_t)。
  • 失败:返回string::npos(一个极大的无符号整数,表示未找到)。

🔧 示例一:查找子串

std::string s = "hello world"; size_t pos = s.find("world"); // 返回 6

🔧 示例二:查找字符

std::string s = "abcabc"; size_t pos = s.find('b'); // 返回 1,第一个 b 的位置

🔧 示例三:未找到

std::string s = "hello"; size_t pos = s.find("abc"); if (pos == std::string::npos) std::cout << "not found";

🔧 示例四:从指定位置开始查找

std::string s = "abcabc"; size_t pos = s.find('b', 2); // 返回 4,跳过前面的 b

🎯 二、其他查找方法汇总

1️⃣rfind:从右往左找(返回最后一次出现的位置)

std::string s = "abcabc"; size_t pos = s.rfind('b'); // 返回 4

2️⃣find_first_of:查找任一字符第一次出现的位置

std::string s = "hello world"; size_t pos = s.find_first_of("aeiou"); // 返回 1,‘e’是第一个元音

3️⃣find_last_of:查找任一字符最后一次出现的位置

std::string s = "abcabc"; size_t pos = s.find_last_of("ab"); // 返回 4,‘b’在位置4最后出现

4️⃣find_first_not_of:找第一个不是指定字符集的字符

std::string s = "aaaabc"; size_t pos = s.find_first_not_of('a'); // 返回 4,‘b’不是 ‘a’

5️⃣find_last_not_of:找最后一个不是指定字符集的字符

std::string s = "abcddd"; size_t pos = s.find_last_not_of('d'); // 返回 2,‘c’不是 ‘d’

📘 实战对比与举一反三

函数名含义查找方向典型用途
find第一次出现左→右查找特定子串或字符
rfind最后一次出现右→左查找最后一个位置
find_first_of第一次出现(任一)左→右查找多个候选字符之一
find_last_of最后一次出现(任一)右→左
find_first_not_of第一个不是指定字符左

相关新闻

  • STM32G491RE与TPAFE0808实现多通道信号采集方案
  • GPT-5.5 多智能体协作能力初探:构建自主任务流的技术验证
  • 知医邦ChatiSS查体大模型:四大核心应用场景全面赋能中医全生命周期

最新新闻

  • 大模型推理加速核心:KV Cache 复用机制与内存布局优化
  • 大模型推理加速年度趋势:从量化到稀疏化的技术跃迁路径
  • Nuke Survival Toolkit:150个Nuke插件的终极指南与完整解决方案
  • 开启 OpenFeign 调用日志打印
  • CAD二次开发中的公差控制
  • Electron + Rust:吉他谱播放器性能优化实战

日新闻

  • Python Playwright录制功能:从零到一构建自动化测试脚本
  • 如何用开源工具永久保存你心爱的小说:novel-downloader全攻略
  • In-Context Learning不是教知识,而是模式对齐:从5个示例到100个工业级样本的真相

周新闻

  • Windows字体自定义终极方案:No!! MeiryoUI完全指南
  • Deepin Boot Maker:告别命令行,3分钟制作Linux启动盘的智能解决方案
  • Plain Craft Launcher 2:重新定义你的Minecraft游戏体验

月新闻

  • 2026年6月公司网站搭建最新热门渠道测评:四大低成本/零代码平台对比+避坑
  • 【Linux】Linux arm 编译QT程序,出现expected “}“报错
  • 【MATLAB例程】四基站二维AOA定位与距离辅助增强对比仿真。基于角度观测和测距修正的固定目标平面定位精度分析

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号