首页 > 其他 > 详细

剑指OFFER之替换空格

时间:2014-12-07 00:00:04      阅读:415      评论:0      收藏:0      [点我收藏+]
题目描述:

请实现一个函数,将一个字符串中的空格替换成“%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
****************************************************************/

 

剑指OFFER之替换空格

原文:http://www.cnblogs.com/Murcielago/p/4148913.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!