腾讯2016面试题

2、字符移位

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

输入描述:

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

输出描述:

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

输入例子:

AkleBiCeilD

输出例子:

kleieilABCD

#include <string.h>
#include <ctype.h>
#include <iostream>
#define N 1000
using namespace std;
int main(int argc, char const *argv[])
{
	char pstr[N];
	memset(pstr,0,sizeof(pstr)); 
    gets(pstr);
    int len = strlen(pstr);
    int i,j;
    int k;
    for (i = len-1;i >= 0;i--){//从尾部开始
    	
    	if (islower(pstr[i])){//如果是小写字母就要往前移动寻找大写字母
           
           for (j = i-1;j >= 0;j--){//从前一位开始寻找大写字母
           	 
           	 if (isupper(pstr[j])){//找到了大写字母
               char tmp = pstr[j];//存储大写字母
               
               for (k = j;k < i;k++){//把小写字母和小字母到大写字母的往前移动一位
               	 pstr[k] = pstr[k+1];
               }
               pstr[i] = tmp;//大写字母代替之前的小写字母
               break;
           	 }
           }
    	}
    }
    cout<<pstr<<endl;
	return 0;
}






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值