代码随想录算法训练营第八天| LeetCode 344.反转字符串 541. 反转字符串II 151.翻转字符串里的单词
344.反转字符串
卡哥建议: 本题是字符串基础题目,就是考察 reverse 函数的实现,同时也明确一下 平时刷题什么时候用 库函数,什么时候 不用库函数
题目链接/文章讲解/视频讲解:https://programmercarl.com/0344.%E5%8F%8D%E8%BD%AC%E5%AD%97%E7%AC%A6%E4%B8%B2.html
做题思路:
可以用双指针法,前后用两个指针,再把两个指针的内容相互交换,两个指针不能移到中间。交换的库函数是swap(a,b),参数a和b可以是任何数据类型,该函数不返回任何内容,它交换两个变量的值。
代码,字符串用vector容器存放:
1 #include <iostream>
2 #include <vector>
3 using namespace std;
4 void reverseString(vector<char>& s) {
5 int l = 0;
6 int r = s.size() - 1;
7 while(l < r)
8 {
9 swap(s[l],s[r]); //交换库函数
10 l++;
11 r--;
12 }
13 }
14 int main()
15 {
16 vector<char> s;
17
18 int n;
19 cin >> n;
20 for(int i = 0; i < n; i++)
21 {
22 char num = 0;
23 cin >> num;
24 s.push_back(num);
25 }
26 reverseString(s);
27 for(vector<char>::iterator it = s.begin(); it != s.end(); it++) //vector容器的遍历
28 {
29 cout << (*it);
30 }
31 cout << endl;
32 return 0;
33 }
运行结果:

541. 反转字符串II
卡哥建议:本题又进阶了,自己先去独立做一做,然后在看题解,对代码技巧会有很深的体会。
题目链接/文章讲解/视频讲解:https://programmercarl.com/0541.%E5%8F%8D%E8%BD%AC%E5%AD%97%E7%AC%A6%E4%B8%B2II.html
做题思路:
题目说每计数至 2k 个字符,就反转这 2k 个字符中的前 k 个字符,那要先找到2k个字符。用for循环有 i++,是每次一个的遍历;还有 i += 2k,是每次2k 的遍历。其中反转题目有要求,在2k个把前k个反转了;还有剩余字符理解的话就是没凑够要反转的k个的字符;前 k 个字符不能反转后,那就是剩余字符反转的问题,所以一开始不用处理剩余字符的问题。
本题代码:
1 string reverseStr(string s, int k) {
2 for (int i = 0; i < s.size(); i += (2 * k)) {
3 // 1. 每隔 2k 个字符的前 k 个字符进行反转
4
5 if (i + k <= s.size()) { //不能在空子串里操作
6 reverse(s, i, i + k - 1); // 2. 剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符
7 continue; //反转前k个后,结束这一轮循环,不用走到下面的代码了
8 }
9 // 3. 剩余字符少于 k 个,则将剩余字符全部反转。
10 reverse(s, i, s.size() - 1); //将s中当前字符到末尾字符全部反转
11 }
12 return s;
13 }
151.翻转字符串里的单词
卡哥建议:这道题目基本把 刚刚做过的字符串操作 都覆盖了,不过就算知道解题思路,本题代码并不容易写,要多练一练。
题目链接/文章讲解/视频讲解:https://programmercarl.com/0151.%E7%BF%BB%E8%BD%AC%E5%AD%97%E7%AC%A6%E4%B8%B2%E9%87%8C%E7%9A%84%E5%8D%95%E8%AF%8D.html
做题思路:
整体思路见卡哥的文章。双指针移除空格的思路和之前移除元素的思路是一样的。快指针去找字符串中不为空的字母,慢指针除了把这个不为空的字母对应的位置记录下来,同时向后移动,还要做好分割成单个单词的操作,就是单词间加一个空格。
在处理空格时,先可以选择忽略空格,就是在一个没有空格的字符串里操作;再利用快指针把不为空的单词收集起来,如果快指针遇到空了,那慢指针此时要在这个位置加空格,如果是整个字符串的第一个单词,我们不需要加空格,因为除了第一个单词前面外,第二个单词.....他们前面要加空格,这个要在找空格的while循环一开始判断,紧接着慢指针加1,再去找下一个单词,再找空格。
本题代码:
1 void reverse(string& s, int start, int end){ //翻转,区间写法:左闭右闭 []
2 for (int i = start, j = end; i < j; i++, j--) {
3 swap(s[i], s[j]);
4 }
5 }
6
7 void removeExtraSpaces(string& s) {//去除所有空格并在相邻单词之间添加空格, 快慢指针。
8 int slow = 0; //整体思想参考https://programmercarl.com/0027.移除元素.html
9 for (int i = 0; i < s.size(); ++i) { //这个i和while循环的i意义不同,这个i是为了控制初快指针的始条件,和移动关系不大
10 if (s[i] != ' ') { //遇到非空格就处理,即删除所有空格,忽略掉s的空格
11 if (slow != 0) s[slow++] = ' '; //手动控制空格,给单词之间添加空格。slow != 0说明不是第一个单词,需要在单词前添加空格。
12 while (i < s.size() && s[i] != ' ') { //补上该单词,遇到空格说明单词结束。
13 s[slow++] = s[i++]; //快慢指针向后移动
14 }
15 }
16 }
17 s.resize(slow); //slow的大小即为去除多余空格后的大小,更新slow
18 }
19
20 string reverseWords(string s) { //反转单词
21 removeExtraSpaces(s); //去除多余空格,保证单词之间之只有一个空格,且字符串首尾没空格。
22 reverse(s, 0, s.size() - 1);
23 int start = 0; //removeExtraSpaces后保证第一个单词的开始下标一定是0。
24 for (int i = 0; i <= s.size(); ++i) {
25 if (i == s.size() || s[i] == ' ') { //到达空格或者串尾,说明一个单词结束。进行翻转。
26 reverse(s, start, i - 1); //翻转,注意是左闭右闭 []的翻转。
27 start = i + 1; //更新下一个单词的开始下标start,下一次反转要知道从哪个位置反转
28 }
29 }
30 return s;
31 }
代码随想录算法训练营第八天| LeetCode 344.反转字符串 541. 反转字符串II 151.翻转字符串里的单词的更多相关文章
- 代码随想录算法训练营day08 | leetcode 344.反转字符串/541. 反转字符串II / 剑指Offer05.替换空格/151.翻转字符串里的单词/剑指Offer58-II.左旋转字符串
基础知识 // String -> char[] char[] string=s.toCharArray(); // char[] -> String String.valueOf(str ...
- 代码随想录算法训练营day01 | leetcode 704/27
前言 考研结束半个月了,自己也简单休整了一波,估了一下分,应该能进复试,但还是感觉不够托底.不管怎样,要把代码能力和八股捡起来了,正好看到卡哥有这个算法训练营,遂果断参加,为机试和日后求职打下一个 ...
- 代码随想录算法训练营day03 | LeetCode 203/707/206
基础知识 数据结构初始化 // 链表节点定义 public class ListNode { // 结点的值 int val; // 下一个结点 ListNode next; // 节点的构造函数(无 ...
- [LeetCode] 344 Reverse String && 541 Reverse String II
原题地址: 344 Reverse String: https://leetcode.com/problems/reverse-string/description/ 541 Reverse Stri ...
- 代码随想录算法训练营day02 | leetcode 977/209/59
leetcode 977 分析1.0: 要求对平方后的int排序,而给定数组中元素可正可负,一开始有思维误区,觉得最小值一定在0左右徘徊,但数据可能并不包含0:遂继续思考,发现元素分布有三种情 ...
- 代码随想录算法训练营day22 | leetcode 235. 二叉搜索树的最近公共祖先 ● 701.二叉搜索树中的插入操作 ● 450.删除二叉搜索树中的节点
LeetCode 235. 二叉搜索树的最近公共祖先 分析1.0 二叉搜索树根节点元素值大小介于子树之间,所以只要找到第一个介于他俩之间的节点就行 class Solution { public T ...
- 代码随想录算法训练营day17 | leetcode ● 110.平衡二叉树 ● 257. 二叉树的所有路径 ● 404.左叶子之和
LeetCode 110.平衡二叉树 分析1.0 求左子树高度和右子树高度,若高度差>1,则返回false,所以我递归了两遍 class Solution { public boolean is ...
- 代码随想录算法训练营day12 | leetcode 239. 滑动窗口最大值 347.前 K 个高频元素
基础知识 ArrayDeque deque = new ArrayDeque(); /* offerFirst(E e) 在数组前面添加元素,并返回是否添加成功 offerLast(E e) 在数组后 ...
- 代码随想录算法训练营day10 | leetcode 232.用栈实现队列 225. 用队列实现栈
基础知识 使用ArrayDeque 实现栈和队列 stack push pop peek isEmpty() size() queue offer poll peek isEmpty() size() ...
- 代码随想录算法训练营day06 | leetcode 242、349 、202、1
基础知识 哈希 常见的结构(不要忘记数组) 数组 set (集合) map(映射) 注意 哈希冲突 哈希函数 LeetCode 242 分析1.0 HashMap<Character, Inte ...
随机推荐
- Java SE 20 新增特性
Java SE 20 新增特性 作者:Grey 原文地址: 博客园:Java SE 20 新增特性 CSDN:Java SE 20 新增特性 源码 源仓库: Github:java_new_featu ...
- 我的web系统设计规范
以下是我自己在工作中总结的,仅供参考. ·应对所有用户输入进行trim()去除两头空格,若是需要空格的应用 转义代替,不应在js里trim(),而应该在数据库端或后端控制,且只在一处拦截控制,更改策略 ...
- vue项目使用rem布局刷新页面瞬间元素尺寸由小变大,页面闪现错乱样式
vue项目使用px2remLoader插件,在index.html自定义设置font-size的大小,尤其是在首屏加载的时候,会出现页面各个元素尺寸由小变大的一个过程,很难看 刚开始一直在想是不是因为 ...
- 2023-02-15:商场中有一展柜A,其大小固定,现已被不同的商品摆满, 商家提供了一些新商品B,需要对A中的部分商品进行更新替换, B中的商品可以自由使用,也就是可以用B中的任何商品替换A中的任何
2023-02-15:商场中有一展柜A,其大小固定,现已被不同的商品摆满, 商家提供了一些新商品B,需要对A中的部分商品进行更新替换, B中的商品可以自由使用,也就是可以用B中的任何商品替换A中的任何 ...
- 2021-05-14:给定一个数组arr,想知道arr中哪两个数的异或结果最大。返回最大的异或结果。
2021-05-14:给定一个数组arr,想知道arr中哪两个数的异或结果最大.返回最大的异或结果. 福大大 答案2021-05-14: 前缀树.一个数,用二进制表示,0走左边分支,1走右边分支.准备 ...
- Vulnhub Broken
Vulnhub Broken 一.操作文档 [Vulnhub - Broken-Gallery writeup (mzfr.me)](https://blog.mzfr.me/vulnhub-writ ...
- vue cli3 整合Cesium,处理build 时内存溢出问题
一直使用cesium,但是都是使用script直接引入的,但是在将其放置在增加路由的子页面中中时会出现一个问题,刷新后提示cesium is undefined 看直接引入cesium.js < ...
- ODOO13之七:Odoo 13开发之记录集 – 使用模型数据
在上一篇文章中,我们概览了模型创建以及如何从模型中载入和导出数据.现在我们已有数据模型和相关数据,是时候学习如何编程与其进行交互 了.模型的 ORM(Object-Relational Mapping ...
- UART-UART非常见波特率调试应用笔记
UART非常见波特率调试 应用笔记 串口通信中的波特率选择,对于确保可靠的数据传输至关重要.波特率是衡量单位时间内传输的比特数,常见的波特率包括300.1200.2400.9600.115200等.不 ...
- SD协议-命令响应
1.CRC 发送命令或数据的时候,都需要经过芯片的IO口,SD Host和SD卡是通过PCB的走线连接在一起的,SD Host IO --> PCB线 --> SD Card IO,PCB ...