栏目分类:
子分类:
返回
终身学习网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
终身学习网 > IT > 软件开发 > 后端开发 > C/C++/C#

反转字符串II(C++)

C/C++/C# 更新时间:发布时间: 百科书网 趣学号
题目:给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。 如果剩余字符少于 k 个,则将剩余字符全部反转。 如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。

leetcode链接

示例 1: 输入:s = “abcdefg”, k = 2 输出:“bacdfeg”

示例 2: 输入:s = “abcd”, k = 2 输出:“bacd”

思路:定义一个指针i,i每次移动2*k步,再定义left指针和right指针,left=i,right=i+k-1。对[left,right]区间内的数据进行反转。

代码:

class Solution {	//反转字符串II
public:
	string reverseStr(string s, int k) {
		int left, right;
		for (int i = 0; i < s.size(); i += (2 * k)) {
			left = i;
			right = i + k - 1;
			if (right >= s.size()) {
				right = s.size() - 1;
			}
			while (left < right) {
				swap(s[left], s[right]);
				left++;
				right--;
			}
		}
		return s;
	}
};

int main()
{
	string s = "abcdefg";
	Solution solution;
	string temp = solution.reverseStr(s, 2);
	for (char i : temp)
		printf("%ct", i);
	printf("n");
	return 0;
}
转载请注明:文章转载自 www.051e.com
本文地址:http://www.051e.com/it/925463.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 ©2023-2025 051e.com

ICP备案号:京ICP备12030808号