题目1510:替换空格
时间限制:1 秒
内存限制:128 兆
特殊判题:否
提交:2553
解决:677
题目描述:
请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
输入:
每个输入文件仅包含一组测试样例。
对于每组测试案例,输入一行代表要处理的字符串。
输出:
对应每个测试案例,出经过处理后的字符串。
样例输入:
We Are Happy
样例输出:
We%20Are%20Happy
题解
本体题型很是常规,通常可以采用从左到右依次移动处理每个元素,此过程中涉及到移动后续元素,时间复杂度为O(n^2);为了减小时间复杂度,可以额外开辟另一数组,牺牲空间换取时间,此算法时间复杂度为O(n);仔细一想,可以尝试从右到左在原数组基础上处理,时间复杂度可以有效降到O(n)且不额外开辟存储空间。
#include<iostream> #include<cstring> #include<cstdio> #include<string> using namespace std; int main() { string str; char ch[10000000]; while(getline(cin,str)) //while(gets(ch)) { int i,count=0,size=str.size(); for(i=0;i<size;i++) { if(str[i]==' ')count++; } i=size-1; ch[i+1+count*2]=0; while(i>=0) { if(str[i]==' ') { ch[i+count*2]='0'; ch[i+count*2-1]='2'; ch[i+count*2-2]='%'; count--; } else ch[i+count*2]=str[i]; i--; } printf("%s\n",ch); } return 0; }