问题:假如一个字符串为“I am a boy”,要求用‘%20’来替换其中的空格。
由于空格只占一个字符,而“%20”占三个字符所以当我们直接替换是,就会覆盖后面的内容,如果每替换之前先将后面的内容后移两个字符那么可以解决,可是复杂度为O(n^2)
.
. 当然我们可以新开辟一个大的空间来存储,但是这样空间复杂度又上去了。那么我们该怎么办呢

解决方法:
我们先扫面一遍数组,找出其中空格的个数,从而统计处新的字符长度,进而从后往前替换,这样就不需要移位复杂度O(n)。是不是很不错呢。(默认原数组空间足够)
#include<stdio.h>
#include <string>
void Spacereplace(char a[])
{
int len = strlen(a);
int spacelen = 0;
int i = 0;
if(NULL == a)
return;
while(a[i] != '\0')
{
if(' '==a[i++])
spacelen++;
}
int newlen = (len+1)+spacelen * 2; //字符串新长度
while(newlen>=0) //替换
{
if(' ' == a[len+1])
{
a[newlen--] = '0';
a[newlen--] = '2';
a[newlen--] = '%';
len--;
}
else
{
a[newlen--] = a[len+1];
len--;
}
}
}
void main()
{
char a[40]="I am a boy";
Spacereplace(a);
printf("%s",a);
}
相关问题:
如果两个数组A,B,已经按照顺序排好。请将B的复制到A中并且所有仍然有序。这个问题可以采用归并的思想,再加上从后往前的思想,这样效率将会非常之高。
总结:合并两个数组,如果向后复制需要移动可以考虑从后往前的思想。

823

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



