杭州建设主管部门的网站做ppt接单的网站
字符串_ 反转字符串II
- 一、leetcode-541
- 二、题解
- 1.引库
- 2.代码
一、leetcode-541
反转字符串II)
给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。
如果剩余字符少于 k 个,则将剩余字符全部反转。
如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。
输入:s = “abcdefg”, k = 2
输出:“bacdfeg”
二、题解
1.引库
#include <iostream>#include <cstdio>#include <cstdlib>#include <queue>#include <stack>#include <algorithm>#include <string>#include <map>#include <set>#include <vector>using namespace std;
2.代码
class Solution {
public:void reverse(string &s,int start,int end){for(int i=start,j=end;i<j;i++,j--){swap(s[i],s[j]);}}string reverseStr(string s, int k) {for(int i=0;i<s.size();i+=2*k){// 1. 每隔 2k 个字符的前 k 个字符进行反转// 2. 剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符if(i+k<=s.size()){reverse(s,i,i+k-1);continue;}// 3. 剩余字符少于 k 个,则将剩余字符全部反转。reverse(s,i,s.size()-1);}return s;}
};