牛客网C++编程题(二) 替换空格

题目描述

请实现一个函数,将一个字符串中的空格替换成“%20”。

例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

class Solution {
public:
	void replaceSpace(char *str,int length) {

	}
};

解题思路

  • 示例代码表示,传入的是字符串指针(char* str)和字符串数组(int length)大小,返回值为void,即要求我们在指针原指向的内存区域进行替换,而不是开辟新的内存空间
  • 如何进行替换,有两种思路: 

  • 1.从前往后(不推荐)    
  • "从前往后"遍历并替换,后续操作较繁琐,因为每找到一个空格时,便需要移动空格后的所有的字符。

  • 2.从后往前(推荐)
  • 因为最终输出的字符串元素要比输入的多,所以计算好输出元素数量后,便"已知"的每个字符元素的位置。从后向前操作,不需要移动空格后所有的字符,操作简单很多

具体步骤

  1. 先判断输入的字符串和长度值是否有效
  2. 计算字符串有效长度和空格数量
  3. 计算最终输出字符串有效长度
  4. "从后向前"替换字符/空格

代码

// Summary: 请实现一个函数,将一个字符串中的空格替换成“%20”。
//          例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。
// Author: Amusi
// Date:   2017-10-28
// Reference:
//思路
//1:从前往后插入,这样移动的次数多(不建议)
//2:从后往前插入(推荐)

#include <iostream>

using namespace std;

class Solution {
public:
	void replaceSpace(char *str, int length) {
		// 0. 判断输入字符串字符有效
		if (str == NULL || length < 1)
			return;
		int i = 0;
		int inputStrLength = 0;		// 字符串长度
		int spaceCounts = 0;
		// 1. 计算字符串中空格数量
		while('\0' != str[i])
		{
			++inputStrLength;
			if (' ' == str[i])
				++spaceCounts;
			++i;
		}
		// 2. 计算最终输出字符串的总长度
		int outputStrLength = inputStrLength + spaceCounts * 2;	
		if (outputStrLength > length)
			return;
		// 3. 从后往前替换
		while (inputStrLength >=0 && outputStrLength > inputStrLength)
		{
			if (str[inputStrLength] == ' ')	// 遇到空格,就替换
			{
				str[outputStrLength--] = '0';
				str[outputStrLength--] = '2';
				str[outputStrLength--] = '%';
			}
			else
			{
				str[outputStrLength--] = str[inputStrLength];
			}
			inputStrLength--;	// 向后移动
		}

	}
};

int main()
{
	const int length = 100;
	char inputStr[length] = "ABC CBA I LOVE YOU!";
	cout << "输入字符串:\t" << inputStr << endl;
	Solution sl;
	sl.replaceSpace(inputStr, length);
	cout << "输出字符串:\t" << inputStr << endl;	

	return 0;
}


  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值