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++是极度关注效率的语言,要是涉及到修改,删除,替换(尾插不算),这样时间复杂 度就会不好。

相关推荐
1白天的黑夜11 分钟前
贪心算法-2208.将数组和减半的最小操作数-力扣(LeetCode)
c++·算法·leetcode·贪心算法
AAAA劝导tx10 分钟前
List--链表
数据结构·c++·笔记·链表·list
格格Code11 分钟前
八大排序——冒泡排序/归并排序
数据结构·算法·排序算法
愚润求学22 分钟前
【Linux】进程优先级和进程切换
linux·运维·服务器·c++·笔记
Dream it possible!25 分钟前
LeetCode 热题 100_最小路径和(92_64_中等_C++)(多维动态规划)
c++·leetcode·动态规划
C语言魔术师42 分钟前
62.不同路径
算法·leetcode·动态规划
fantasy_442 分钟前
LeetCode238☞除自身以外数组的乘积
java·数据结构·python·算法·leetcode
辰哥单片机设计1 小时前
JQ6500语音模块详解(STM32)
数据库·mongodb
椰羊~王小美1 小时前
贪心算法和动态规划
算法·贪心算法·动态规划
纪元A梦1 小时前
华为OD机试真题——阿里巴巴找黄金宝箱Ⅰ(2025A卷:100分)Java/python/JavaScript/C/C++/GO最佳实现
java·c语言·javascript·c++·python·华为od·go