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

相关推荐
Tiandaren20 分钟前
Selenium 4 教程:自动化 WebDriver 管理与 Cookie 提取 || 用于解决chromedriver版本不匹配问题
selenium·测试工具·算法·自动化
胚芽鞘68129 分钟前
关于java项目中maven的理解
java·数据库·maven
岁忧1 小时前
(LeetCode 面试经典 150 题 ) 11. 盛最多水的容器 (贪心+双指针)
java·c++·算法·leetcode·面试·go
chao_7891 小时前
二分查找篇——搜索旋转排序数组【LeetCode】两次二分查找
开发语言·数据结构·python·算法·leetcode
秋说3 小时前
【PTA数据结构 | C语言版】一元多项式求导
c语言·数据结构·算法
Maybyy4 小时前
力扣61.旋转链表
算法·leetcode·链表
sun0077004 小时前
mysql索引底层原理
数据库·mysql
卡卡卡卡罗特6 小时前
每日mysql
数据结构·算法
chao_7896 小时前
二分查找篇——搜索旋转排序数组【LeetCode】一次二分查找
数据结构·python·算法·leetcode·二分查找
蜉蝣之翼❉6 小时前
CRT 不同会导致 fopen 地址不同
c++·mfc