💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
- 推荐:kuan 的首页,持续学习,不断总结,共同进步,活到老学到老
- 导航
非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨
博客目录
给定一个字符串
s
和一个整数k
,从字符串开头算起,每计数至2k
个字符,就反转这2k
字符中的前k
个字符。
- 如果剩余字符少于
k
个,则将剩余字符全部反转。- 如果剩余字符小于
2k
但大于或等于k
个,则反转前k
个字符,其余字符保持原样。
apl
输入:s = "abcdefg", k = 2
输出:"bacdfeg"
输入:s = "abcd", k = 2
输出:"bacd"
java
public static void main(String[] args) {
String a = "abcdefg";//bacdfeg
E04ReverseStr541 e04ReverseStr541 = new E04ReverseStr541();
String reverseStr = e04ReverseStr541.reverseStr(a, 2);
System.out.println(reverseStr);
}
public String reverseStr(String s, int k) {
final char[] chars = s.toCharArray();
final int len = chars.length;
for (int i = 0; i < len; i += 2 * k) {
//起点是i,终点是i+k,或者是len,取小的,k取2,index取的是1
reverse(chars, i, Math.min(i + k - 1, len - 1));
}
return String.valueOf(chars);
}
/**
* 翻转char,翻转字符串
*
* @param chars
* @param left
* @param right
*/
private void reverse(char[] chars, int left, int right) {
while (left < right) {
char temp = chars[left];
chars[left] = chars[right];
chars[right] = temp;
left++;
right--;
}
}
觉得有用的话点个赞
👍🏻
呗。❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄
💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍
🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙