【字符串】常见算法题型及方法总结

什么是字符串?

字符串是若干字符组成的有限序列,可以理解为一个字符数组。在C++中提供了一个string类,那我们可能会想vector<char>和string有什么区别呢。在含义和基本操作方面基本是没有区别的,但是string提供了更多相关接口,比如string重载了+,而vector没有。所以我们一般会通过定义一个string类来处理字符串。

常见题型:

1. 反转字符串

2. 反转字符串Ⅱ

3. 替换数字

4.翻转字符串里的单词

5.右旋字符串

6.重复的子字符串

常见方法:

1. 当需要按照固定规律一段一段处理字符串时,可以在for循环的表达式上做改变,即不一定非要使用i++

2. 整体翻转再局部翻转的思想

3. 双指针法

4. KMP算法:主要思想是当出现字符串不匹配时,可以知道一部分之前已经匹配的文本内容,可以利用这些信息避免从头再去做匹配了。KMP可以用来解决匹配问题和重复字串问题。其中关键点是前缀和后缀。前缀是指不包含最后一个字符的所有以第一个字符开头的连续字串,后缀是指不包含第一个字符的所有以最后一个字符结尾的连续子串。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值