C++: string(二)

✨✨ 欢迎大家来到我的文章✨

🎈🎈养成好习惯,先赞后看哦~🎈🎈

分类专栏:c++

我的主页:tyler 's blog

文章目录

string与容器很像虽然没归类到容器内,我们完全可以把它归到容器内讲解

一 string的成员函数

1 insert

随着字符增加,头插效率越来越低

其他还有迭代器版本和其他的版本就不演示了

2 resize

有一个重载,第一个是把默认成员移到第n个位置,第二个函数是把默认成员移到第n个位置(size所在地)

n>capacity就扩容,

n<capacity插入
我们知道string的底层类似于栈的结构,也是有capacity ,size之类的默认成员变量的。

3assign

这个用的比较少,是从某字符起到分配作用

4erase

我们用的是第一个重载接口比较多erase(0,x),这就是头删

5replace

我们甚至会看到5个参数的replace

数字都是从pos开始之后len个字符

6 find

(1) find

find接口是返回的size_t来寻找指定字符或者字符串

find可以和replace配合使用,来循环改变指定字符,如下面把l替换为空格。

上面npos是静态成员变量可以根据类名直接::访问,因为没找到失败是返回npos,所以我们这里循环条件是!=npos

这里时间效率会很低,因为涉及到数据挪动

我们可以再定义string s2,以空间换时间

这里时间 复杂度为O(n)比上面replace好多了,原理是以空间换时间。

(2)rfind

这是从后往前找你指定的字符,和find是反着来的,不演示了。

(3)find_first_not_of

这是寻找不是str内字符串内字符位置

我们可以这样删除指定字符

(4)find_first_of

和刚刚find_first_not_of相反不做赘述

7substr

这个很重要是从截取指定位置到指定位置字符串

二总结

1 我们这章学习了string的成员函数,在https://legacy.cplusplus.com/

网站中可以把接口分为按不同标准分成好多类(如下面Capacity,Element access),下面是我们在string常用的

其他不常用的我们要么有替代接口或者功能不常用

2 c++是极度关注效率的语言,要是涉及到修改,删除,替换(尾插不算),这样时间复杂 度就会不好。

相关推荐
地平线开发者31 分钟前
Transformer模型部署之性能优化指南
算法
地平线开发者1 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
ClouGence3 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
半个落月4 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星5 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星5 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
飞将5 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
To_OC20 小时前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与1 天前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法