题目描述:给你一段字符串,把字符串中的每个空格替换成"%20",比如 I love China,则输出"I%20love%20China".
在网络编程中,如果URL参数中含有特殊参数,如空格,'#'等,可能导致服务器无法获得正确的参数值。我们需要将这些特殊符号转换成服务器能识别的字符。转换的规则是在'%'后面跟上ASCII码的两位16进制的表示。比如空格的ASCII码是32,16进制是0x20。空格可被替换成'%20'。再比如'#'的ASCII码为35,即16进制的0x35,它在URL中被替换成'%23';
思路一:从头扫到尾,每一次碰到空格字符做替换,由于是把1个字符替换成3个字符,我们必须把空格后面所有的字符都后移两个字节,否则就有两个字符被覆盖了;
总结:假设字符串的长度为n,对每个空格字符,需要移动后面O(n)个字符,因此对含有O(n)个字符的字符串来言总的时间复杂度为O(n2);
(优化)思路二:
先遍历一次字符串,统计出空格数,计算出替换之后替换的长度=原长度+(空格数)*2;
从字符串的后面开始复制和替换。准备两个指针i,j。i指向原字符串的末尾,j指向替换之后的字符串的末尾。
当str[i]!=' '向前移动i,j。复制str[i]到str[j];
当str[i]=' ',i往前移动,j向前移动3格插入"%20";
知道i和j指向同一位置
总结:所有的字符只需要复制(移动)一次,算法的时间复杂度为O(n),比思路一要快
代码:
#include<iostream>
#include<cstdio>
#include<cstring>
#define M 100
using namespace std;
char str[M];
/// I%20love China
/// "I%20love%20China"
int l;
void show()
{
for(int i=0;i<l;++i)
printf("%c",str[i]);
printf("\n");
memset(str,0,sizeof(str));
}
void solve1() //思路一
{
if(l<=0) return ;
int i,j;
for(i=0;i<l;++i)
{
if(str[i]==' ')
{
str[i]='%';
l+=2;
for(j=l;j>=i+3;--j)
{
str[j]=str[j-2];
}
str[i+1]='2';
str[i+2]='0';
}
}
}
void solve2() //思路二
{
if(l<=0) return ;
int i=0,j,t=0; //t用于记录空格的个数
while(i<l)
{
if(str[i++]==' ')
t++;
}
l+=t*2;
j=l;
while(i<j)
{
if(str[i]==' ')
{
i--;
str[j]='0';
str[j-1]='2';
str[j-2]='%';
j-=3;
}
else
{
str[j]=str[i];
i--;
j--;
}
}
}
int main()
{
while(gets(str))
{
l=strlen(str);
// sovle1();
solve2();
show();
}
return 0;
}
本文介绍了一种高效的URL空格转义算法,该算法通过两次遍历来实现空格的%20替换,避免了传统方法中多次移动字符的问题,有效提升了处理效率。
7004

被折叠的 条评论
为什么被折叠?



