“从后往前”解决复制问题

问题:假如一个字符串为“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中并且所有仍然有序。这个问题可以采用归并的思想,再加上从后往前的思想,这样效率将会非常之高。
总结:合并两个数组,如果向后复制需要移动可以考虑从后往前的思想。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值