您的位置:首页 > 其它

小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间。 你能帮帮小Q吗?

2016-08-19 16:42 441 查看


小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间。
你能帮帮小Q吗?

[b]输入描述:[/b]
输入数据有多组,每组包含一个字符串s,且保证:1<=s.length<=1000.

[b]输出描述:[/b]

对于每组数据,输出移位后的字符串。

[b]输入例子:[/b]
AkleBiCeilD


[b]输出例子:[/b]
kleieilABCD


#include<string>
#include<iostream>
using namespace std;
void move(string &str)
{
for(int i=str.size()-1;i>=0;i--)
{
if(str[i]>='A'&&str[i]<='Z')
continue;
else
{
int begin=i;
while(str[begin]>='a'&&str[begin]<='z'&&begin>=0)
{
begin--;

}
if(begin>=0)
{
char ch=str[begin];
for(int j=begin+1;j<=i;j++)
{
str[j-1]=str[j];
}
str[i]=ch;
}
}
}
}
int main()
{
string str;
while(cin>>str)
{
move(str);
cout<<str<<endl;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐