LeetCode 541. 反转字符串 II
生活随笔
收集整理的這篇文章主要介紹了
LeetCode 541. 反转字符串 II
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1. 題目
給定一個字符串和一個整數 k,你需要對從字符串開頭算起的每個 2k 個字符的前k個字符進行反轉。如果剩余少于 k 個字符,則將剩余的所有全部反轉。如果有小于 2k 但大于或等于 k 個字符,則反轉前 k 個字符,并將剩余的字符保持原樣。
示例: 輸入: s = "abcdefg", k = 2 輸出: "bacdfeg"要求: 該字符串只包含小寫的英文字母。 給定字符串的長度和 k 在[1, 10000]范圍內。來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/reverse-string-ii
著作權歸領扣網絡所有。商業轉載請聯系官方授權,非商業轉載請注明出處。
2. 解題
class Solution { public:string reverseStr(string s, int k) {for(int i = 0; i < s.size(); i += 2*k){if(i+k <= s.size())revStr(s,i,i+k-1);elserevStr(s,i,s.size()-1);}return s;}void revStr(string &s, int i, int j){while(i < j)swap(s[i++],s[j--]);} };總結
以上是生活随笔為你收集整理的LeetCode 541. 反转字符串 II的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: LeetCode 454. 四数相加 I
- 下一篇: LeetCode 443. 压缩字符串(