剑指offer:替换空格

题目描述

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

思路:先计算字符串中的空格数count,然后开辟一块新的内存空间大小为length+count*2,然后从头开始拷贝新的字符串,遇到空格就替换成'%','2','0',最后把替换后的字符串地址和源串拷贝过去。

void replaceSpace(char *str,int length) 
{
        
        char* s = str;
        int count = 0;
        while(*s != '\0')
        {
            if(*s == ' ')
            {
                ++count;
            }
            ++s;
        }
        
        char* src = str;
        char* start = (char*)malloc(length + 2*count +1);
        char* cur = start;
        while(*src != '\0')
        {
            if(*src == ' ')
            {
                *start++ = '%';
                *start++ = '2';
                *start++ = '0';
                src++;
            }
            else
                *start++ = *src++;
        }
        *start = '\0';
        strcpy(str, cur);
        
	}

 

全部评论

相关推荐

头像
10-27 15:50
门头沟学院 Java
想进开水团喝开水:有一种店 只能外卖 不能堂食 你猜为什么
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务