替换字符串空格

本算法通过从后遍历字符串实现O(n)的时间复杂度替换字符串中的空格。

void replaceSpace(char *str, int maxLength)
{
	int length = strlen(str);
	int spaceNum = 0;
	for (int i = 0; i < length; i++)
	{
		if (str[i] == ' ')
		{
			spaceNum++;
		}
	}
	int oldIndex = length;
	int newIndex = length + 2 * spaceNum;
	if (newIndex > maxLength)
	{
		return;
	}
	while (newIndex > oldIndex)
	{
		if (str[oldIndex] == ' ')
		{
			str[newIndex--] = '0';
			str[newIndex--] = '2';
			str[newIndex--] = '%';
			oldIndex--;
		}
		else
		{
			str[newIndex--] = str[oldIndex--];
		}
	}
}


总结:合并两个数组(包括字符串)时,如果从前往后复制每个数字(或字符)需要重复移动数字(或字符)多次,那么可以考虑从后往前复制,这样就能减少复制的次数,从而提高效率。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值