剑指OFFER之替换空格

题目描述:

请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

 

输入:

每个输入文件仅包含一组测试样例。
对于每组测试案例,输入一行代表要处理的字符串。

 

输出:

对应每个测试案例,出经过处理后的字符串。

 

样例输入:
We Are Happy
样例输出:
We%20Are%20Happy

Code:
#include <stdio.h>
#include <stdlib.h>
 
void ReplaceBlank(char str[]){
    if(str==NULL)
        return;
    int originalLength=0;
    int numberOfBlank=0;
    int i=0;
    while(str[i]!='\0'){
        ++originalLength;
        if(str[i]==' '){
            ++numberOfBlank;
        }
        ++i;
    }
    int newLength=originalLength+2*numberOfBlank;
    while(originalLength>=0){
        if(str[originalLength]!=' '){
            str[newLength--]=str[originalLength--];
        }else{
            --originalLength;
            str[newLength--]='0';
            str[newLength--]='2';
            str[newLength--]='%';
        }
    }
}
 
int main()
{
    char str[1000000];
    while(gets(str)){
        ReplaceBlank(str);
        printf("%s\n",str);
    }
    return 0;
}
 
/**************************************************************
    Problem: 1510
    User: lcyvino
    Language: C
    Result: Accepted
    Time:10 ms
    Memory:1820 kb
****************************************************************/

 

posted @ 2014-12-06 22:46  tinylcy  阅读(159)  评论(0编辑  收藏  举报