首页 > 代码库 > 替换字符串中的空格
替换字符串中的空格
版权声明:本文为博主原创文章,未经博主允许不得转载。
转载请注明出处:http://blog.csdn.net/ns_code/article/details/25002199
剑指offer上的第四道题目,在九度OJ上测试通过,但还是有些问题,因为是用C语言实现的,因此,要提前开辟一个比较大的空间来存储输入的字符串。而如果在线测试系统的测试用例中字符串的长度大于该最大值的话,会报RE,但是九度OJ的测试用例没有大于我所设定的字符串的最大值。当然,这道题目用C++中的string类或java中的String类实现会更好,不需要担心输入字符串的长度。
时间限制:1 秒
内存限制:128 兆
- 题目描述:
请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
- 输入:
每个输入文件仅包含一组测试样例。
对于每组测试案例,输入一行代表要处理的字符串。
- 输出:
对应每个测试案例,出经过处理后的字符串。
- 样例输入:
We Are Happy
- 样例输出:
We%20Are%20Happy
[cpp] view plain copy
- #include<stdio.h>
- #include<string.h>
- #include<stdlib.h>;
- char *ReplaceBlank(char *str)
- {
- if(str == NULL)
- return NULL;
- int len = strlen(str);
- if(len == 0)
- return NULL;
- int i,count = 0;
- for(i=0;i<len;i++)
- if(str[i] == ‘ ‘)
- count++;
- //没有空格,就直接返回str
- if(count == 0)
- return str;
- int new_len = 2*count+len+1;
- char *dest = (char *)malloc(new_len*sizeof(char));
- if(dest == NULL)
- exit(EXIT_FAILURE);
- int j = 0;
- for(i=0;i<len;i++)
- {
- if(str[i] != ‘ ‘)
- {
- dest[j++] = str[i];
- }
- else
- {
- dest[j] = ‘%‘;
- dest[j+1] = ‘2‘;
- dest[j+2] = ‘0‘;
- j += 3;
- }
- }
- dest[j] = ‘\0‘;
- return dest;
- }
- int main()
- {
- //虽然AC了(主要九度的测试用例没有大于这个范围的),但是人为地限制str的长度并不是最佳的方法,
- //最好使用C++中的string类或java中的String类,
- //但目前在C语言中,我还不知道怎么可以不限定长度地从键盘接受输入的字符串。
- static char str[10000000];
- gets(str);
- char *dest = ReplaceBlank(str);
- if(dest != NULL)
- puts(dest);
- free(dest);
- dest = NULL;
- return 0;
- }
替换字符串中的空格
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。