本文主要是介绍2021-5-28 剑指 Offer 58 - II. 左旋转字符串(原地修改),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
注:
题目:
字符串的左旋转操作是把字符串前面的若干个字符转移到字符串的尾部。请定义一个函数实现字符串左旋转操作的功能。比如,输入字符串"abcdefg"和数字2,该函数将返回左旋转两位得到的结果"cdefgab"。
示例 1:
输入: s = “abcdefg”, k = 2
输出: “cdefgab”
示例 2:
输入: s = “lrloseumgh”, k = 6
输出: “umghlrlose”
限制:
1 <= k < s.length <= 10000
题解:
不使用内置函数+原地修改字符串
class Solution {
public:string reverseLeftWords(string s, int n) {string str="";for(int i=0;i<n;i++){str+=s[i];}int size=s.size();for(int i=0;i<size-n;i++){s[i]=s[i+n];}for(int i=size-n;i<size;i++){s[i]=str[i-(size-n)];}return s;}
};
这篇关于2021-5-28 剑指 Offer 58 - II. 左旋转字符串(原地修改)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!