代码随想录 字符串篇
一、反转字符串
力扣题目链接
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s
的形式给出。
不要给另外的数组分配额外的空间,你必须**原地修改输入数组**、使用 O(1) 的额外空间解决这一问题。
示例 1:
1 2
| 输入:s = ["h","e","l","l","o"] 输出:["o","l","l","e","h"]
|
示例 2:
1 2
| 输入:s = ["H","a","n","n","a","h"] 输出:["h","a","n","n","a","H"]
|
提示:
1 <= s.length <= 105
s[i]
都是 ASCII 码表中的可打印字符
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| class Solution { public void reverseString(char[] s) { int left = 0 , right = s.length - 1; while(left < right){ char tmp = s[left]; s[left] = s[right]; s[right] = tmp; left++; right--; }
} }
|
二、反转字符串2
力扣题目链接
给定一个字符串 s
和一个整数 k
,从字符串开头算起,每计数至 2k
个字符,就反转这 2k
字符中的前 k
个字符。
- 如果剩余字符少于
k
个,则将剩余字符全部反转。
- 如果剩余字符小于
2k
但大于或等于 k
个,则反转前 k
个字符,其余字符保持原样。
示例 1:
1 2
| 输入:s = "abcdefg", k = 2 输出:"bacdfeg"
|
示例 2:
1 2
| 输入:s = "abcd", k = 2 输出:"bacd"
|
提示:
1 <= s.length <= 10^4
s
仅由小写英文组成
1 <= k <= 10^4
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
| class Solution { public String reverseStr(String s, int k) { char [] ch = s.toCharArray(); for (int i = 0; i < ch.length; i+=2*k){ int start = i; int end = Math.min(ch.length-1 , start+k-1); while(start<end){ ch[start] ^= ch[end]; ch[end] ^= ch[start]; ch[start] ^= ch[end]; start++; end--; } } return String.valueOf(ch);
} }
|
借此契机,学习StringBuffer的知识,下面的解题方法也来自于代码随想录,
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
| class Solution { public String reverseStr(String s, int k) { StringBuffer res = new StringBuffer(); int length = s.length(); int start = 0; while (start < length) { StringBuffer temp = new StringBuffer(); int firstK = (start + k > length) ? length : start + k; int secondK = (start + (2 * k) > length) ? length : start + (2 * k);
temp.append(s.substring(start, firstK)); res.append(temp.reverse());
if (firstK < secondK) { res.append(s.substring(firstK, secondK)); } start += (2 * k); } return res.toString(); } }
|
三、替换数字
四、翻转字符串里的单词
五、右旋转字符串
六、实现strStr()
七、重复的子字符串
八、总结篇