C++ 如何在不删除任何字符的情况下将字符从字符串中的某个位置移动到其最前面?

C++ 如何在不删除任何字符的情况下将字符从字符串中的某个位置移动到其最前面?,c++,string,C++,String,我的字符串大约有14个字符长,我必须将一个字符从字符串中的某个位置移到最前面,并且我无法删除已位于myString[0]中的字符。我该怎么做 std::string x = "foobar"; x.insert(0, 1, x[3]); // insert the 4th character at the beginning x.erase(4, 1); // erase the 5th character // (5th because the preced

我的字符串大约有14个字符长,我必须将一个字符从字符串中的某个位置移到最前面,并且我无法删除已位于
myString[0]
中的字符。我该怎么做

std::string x = "foobar";
x.insert(0, 1, x[3]); // insert the 4th character at the beginning
x.erase(4, 1);  // erase the 5th character 
                // (5th because the preceding operation added a character

请参阅的相应成员函数。

作为使用
std::string
函数的替代方法,您可以尝试使用
中的函数

或:


这两项都不会更改字符串的
size()
,并且不应触发内存重新分配。

您是否使用
std::string
?您希望如何处理
myString[0]
?如果你以“苹果”开头并想移动“l”,你想以“拉普”结尾吗?还是“lppae”?或者别的什么?是的,我用的是std::string…如果我的字符串是apple,我必须移动L,它应该是这样的。。。。。。lappe@MokammelSanju事实上,我更喜欢解决方法是高炉。这比我使用卷积字符串成员函数要好得多。我总是忘记旋转。
std::string x = "foobar";
std::rotate(x.begin(), x.begin() + 3, x.begin() + 4); // foobar -> bfooar
std::reverse(x.begin(), x.begin() + 3); // foobar -> oofbar
std::reverse(x.begin(), x.begin() + 4); // oofbar -> bfooar