把一个字符串的大写字母放到字符串的后面--腾讯2017暑期实习生编程题

原创 2016年08月28日 15:32:28

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



输入描述:

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



输出描述:

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


输入例子:
AkleBiCeilD

输出例子:
kleieilABCD
解法:

#include<cstdio>
#include<cstring>
bool isCapital(char ch)
{
    if(ch>='A'&&ch<='Z')
    {
        return true;
    }
    return false;
}
int main()
{
    char str[1001];
    while(scanf(" %s",str)!=EOF)
    {
        int len=strlen(str);
        int num_Of_Judged=0;//判断过的字符数
        for(int i=0;i<len&&num<len;)
        {
            if(isCapital(str[i]))
            {
                char ch=str[i];
                for(int j=i+1;j<len;j++)
                {
                    str[j-1]=str[j];
                }
                str[len-1]=ch;
            }
            else
            {
                i++;//因为将大写字母抽出后,其他字符前移,移动后的字符串的第i个位置仍可能为大写字母
            }
            isCapital++;//判断过的字符数为len时表示全部字符判断完成
        }
         printf("%s\n",str);

    }
}





版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

在一个字符串中把大写字母放到字符串中小写字母的后面(不能改变字母的相对位置)

设置两个下标p1、p2   同时指向字符串的末尾,让p1找到第一次出现为大写的字母的位置,然后从p1至p2两两交换,之后让p1--,p2--,重复以上,直到p1小于0为止   public voi...

字符串面试题(三)— 把一个字符串的大写字母放到字符串的后面

把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,不能申请额外的空间

腾讯2017暑期实习生编程题

1,给定一个字符串s,你可以从中删除一些字符,使得剩下的串是一个回文串。如何删除才能使得回文串最长呢?输出需要删除的字符个数。 输入描述:输入数据有多组,每组包含一个字符串s,且保证:1 输出描述...

腾讯2017暑期实习生编程题

#include #include #include using namespace std; int dp[1005][1005]; int main(){ char s[1005...

腾讯2017暑期实习生编程题之构造回文

题目描述: 给定一个字符串s,你可以从中删除一些字符,使得剩下的串是一个回文串。如何删除才能使得回文串最长呢? 输出需要删除的字符个数。 输入描述: 输入数据有多组,每组包含一个字符串s...

腾讯2017暑期实习生编程题——算法基础-字符移位

腾讯2017暑期实习生编程题——算法基础-字符移位

腾讯2017暑期实习生编程题--有趣的数字

小Q今天在上厕所时想到了这个问题:有n个数,两两组成二元组,差最小的有多少对呢?差最大呢?输入描述:输入包含多组测试数据。对于每组测试数据:N - 本组测试数据有n个数a1,a2…an - 需要计算的...

腾讯2017暑期实习生编程题-C-有趣的数字

ACM模版描述题解这个招聘实习生的编程题真心简单,可是我在牛客网上做的,莫名其妙的 WA,但是我思路肯定没问题啊,本地测试的样例也是过的,可是系统提示说我连样例都错了,这就尴尬了,感觉牛客网的测评系统...
  • f_zyj
  • f_zyj
  • 2017-03-07 22:50
  • 213

腾讯2017暑期实习生编程题

1.构造回文 给定一个字符串s,你可以从中删除一些字符,使得剩下的串是一个回文串。如何删除才能使得回文串最长呢? 输出需要删除的字符个数。输入描述:输入数据有多组,每组包含一个字符串s,且保证:1<...

腾讯2017暑期实习生编程题(3道)

1.构造回文 考点:最长公共子串 //给定一个字符串s,你可以从中删除一些字符,使得剩下的串是一个回文串。如何删除才能使得回文串最长呢? //输入描述:输入数据有多组,每组包含一个字符串s,且保证:...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)