leetcode刷题二 char数组空格替换

char数组空格替换

题目:
请实现一个函数,将一个字符串中的每个空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

c++提供string字符串数据结构,我们可以比较方便的去替换

方法一:利用string的特性

 void replaceSpace(char *str, int length) {
	if (length <= 0) return;
	string s = string(str);
	string res;
	for (auto x : s)
	{
		if (x == ' ')
			res += "%20";
		else
			res += x;
	}
	strcpy(str, res.c_str());

}

方法二:从后往前遍历替换,重点是需要知道char数组的长度

void replaceReverse(char *str, int length)
{
	//hello world 
	//从后向前遍历,如果碰到空格就增加两个空间插入%20 
	if (length <= 0) return;
	int totallen = length;
	int spaceCount = 0;
	for (int i = 0; i < length; ++i)
	{
		if (str[i] == ' ') spaceCount++;
	}
	totallen += spaceCount * 2;//hello world; 11+1*2 = 13;
	for (int j = length - 1; j >= 0 && j!=totallen; j--)
	{
		if (str[j] != ' ') str[--totallen] = str[j];
		else 
		{
			str[--totallen] = '0';
			str[--totallen] = '2';
			str[--totallen] = '%';
		}
	}
		

}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值