Leetcode刷题Day8-------------字符串
创始人
2024-04-13 16:16:49
0

Leetcode刷题Day8-------------字符串

1. 反转字符串 (344)

  • 题目链接:
  • 文章讲解/视频讲解:https://programmercarl.com/0344.%E5%8F%8D%E8%BD%AC%E5%AD%97%E7%AC%A6%E4%B8%B2.html

双指针 或者 for+单指针 都可

class Solution {public void reverseString(char[] s) {int right=s.length-1;for(int i=0;ichar temp=s[i];s[i]=s[right];s[right]=temp;right--;}}
}

2. 反转字符串II (541)

  • 题目链接:https://leetcode.cn/problems/reverse-string-ii/
  • 文章讲解/视频讲解:https://programmercarl.com/0541.%E5%8F%8D%E8%BD%AC%E5%AD%97%E7%AC%A6%E4%B8%B2II.html
    重点:
  1. 题目要求每次只翻转k个,然后k个不翻转,这样为一轮---------------->一轮有2k个,所以用for循环来控制
  2. 题目要求如果最后一轮的一半不到k个,就都翻转,如果够K个就反转k个----------->right 的判定:Math.min(ch.length - 1, start + k - 1);
  3. 库函数:s为 String类型-------> char[] ch = s.toCharArray();
//解法二(似乎更容易理解点)
//题目的意思其实概括为 每隔2k个反转前k个,尾数不够k个时候全部反转
class Solution {public String reverseStr(String s, int k) {char[] ch = s.toCharArray();for(int i = 0; i < ch.length; i += 2 * k){//以下与上题道理相同//这里是判断尾数够不够k个来取决end指针的位置int right=Math.min(ch.length-1,i+k-1);for(int j=i;jchar temp=ch[j];ch[j]=ch[right];ch[right]=temp;right--;}}return new String(ch);}
}

3. 替换空格 (剑指Offer 05)

  • 题目链接/文章讲解:https://programmercarl.com/%E5%89%91%E6%8C%87Offer05.%E6%9B%BF%E6%8D%A2%E7%A9%BA%E6%A0%BC.html

重点:
转为StringBuilder 追加

class Solution {public String replaceSpace(String s) {StringBuilder sb=new StringBuilder();for(int i=0;iif(s.charAt(i)==' ') sb.append("%20");else sb.append(s.charAt(i));}return sb.toString();}
}

4. 翻转字符串里的单词(151)

  • 题目链接:https://leetcode.cn/problems/reverse-words-in-a-string/
  • 文章讲解/视频讲解: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

5. 左旋转字符串 (剑指Offer58-II)

  • 题目链接:
  • 文章讲解:https://programmercarl.com/%E5%89%91%E6%8C%87Offer58-II.%E5%B7%A6%E6%97%8B%E8%BD%AC%E5%AD%97%E7%AC%A6%E4%B8%B2.html

还是 整体旋转+局部旋转!
步骤

  1. 反转区间为前n的子串
  2. 反转区间为n到末尾的子串
  3. 反转整个字符串

注意:处理好调用时的参数-----------> 需要-1,因为含头含尾

class Solution {public String reverseLeftWords(String s, int n) {s=reversString(s,0,n-1);s=reversString(s, n, s.length()-1);s=reversString(s,0,s.length()-1);return s;}public String reversString(String s, int start, int end){char[] ch=s.toCharArray();for(int i=start;ichar temp=ch[i];ch[i]=ch[end];ch[end]=temp;end--;}return new String(ch);}
}

相关内容

热门资讯

哪里找正规一块红中麻将群@百... 1.进群方式《ab120590》或者《mj120590》《tj525555》--QQ(4434063...
「发布」加入附近红中麻将群@(... 群主微【ab120590】 【mj120590】【tj525555】免带押进群,群内跑包包赔支持验证...
《百度科普》24小时一元一分红... 群主微信【ab120590】【tj525555】【mj120590】一元 两元 麻将群跑得快群都有,...
揭秘红中麻将微信群@2024已... 认准管理加v:微【ab120590】【mj120590】【tj525555】七年稳定老群!随时拿起手...
《优酷视频》一元一分红中麻将... 薇新【ab120590】【mj120590】【tj525555】,最火热的跑得快,红中等等。自助上下...
[解读]上下分跑得快红中麻将@... 1.亮点:一元红中麻将微信“群”—ab120590—tj525555—mj120590—客服Q443...
来这里正规靠谱红中麻将群@24... 好运连连,全网推荐:(ab120590)(mj120590)【tj525555】-Q号:(QQ443...
必看科普24小时红中麻将群@2... 认准管理加v:微【ab120590】【mj120590】【tj525555】七年稳定老群!随时拿起手...
火爆正规靠谱红中麻将群@202... 好运连连,全网推荐:(ab120590)(mj120590)【tj525555】-Q号:(QQ443...
《西瓜视频》一元一分微信红中麻... 好运连连,全网推荐:(ab120590)(mj120590)【tj525555】-Q号:(QQ443...
《麻将玩法》24小时一元一分微... 认证群主微信微【ab120590】 【mj120590】【tj525555】(一元俩元红中麻将)(跑...
重大发现手机红中麻将跑的快群@... 1.进群方式-[ab120590]或者《mj120590》【tj525555】--QQ(QQ4434...
桌游常识真人线上一元一分红中麻... 1.亮点:一元红中麻将微信“群”—ab120590—tj525555—mj120590—客服Q443...
《经市财经》哪里有一元一分微信... 群主微【ab120590】【tj525555】 【mj120590】亲友团上下分模式,24小时全天不...
桌游常识一元上下分麻将@202... 1.亮点:一元红中麻将微信“群”—ab120590—tj525555—mj120590—客服Q443...
哪里找哪有一块红中微信群@微博... 群主微【ab120590】【tj525555】 【mj120590】亲友团上下分模式,24小时全天不...
[如何加入]靠谱红中麻将微信@... 1.进群方式《ab120590》或者《mj120590》《tj525555》--QQ(4434063...
「独家解读」24小时不熄火红中... 一元一分麻将群加群主微:微【ab120590】 【mj120590】【tj525555】喜欢手机上打...
必看经典红中麻将微信群@全面升... 加V【ab120590】【tj525555】【mj120590】红中癞子、跑得快,等等,加不上微信就...
今日头条正规红中麻将上下分群@... 1.进群方式-[ab120590]或者《mj120590》【tj525555】--QQ(QQ4434...