Practice33:
汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。
对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。
例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。
S1
class Solution {
public:
string LeftRotateString(string str, int n) {
if (n > str.size()) return str;
string ret = "";
for (int i=n; i<str.size(); ++i)
ret += str[i];
for (int i=0; i<n; ++i)
ret += str[i];
return ret;
}
};
S2
简单解法
class Solution {
public:
string LeftRotateString(string str, int n) {
if (n > str.size()) return str;
return str.substr(n)+str.substr(0,n);
}
};

本文介绍了一种使用字符串模拟循环左移指令的方法。通过两个不同的实现方案,展示了如何将一个字符序列循环左移K位,并给出了具体的代码示例。
2万+

被折叠的 条评论
为什么被折叠?



