替换空格算法分析

Posted LeewinPlus

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了替换空格算法分析相关的知识,希望对你有一定的参考价值。

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

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

分析:

1.首先能想到的肯定是将输入的字符串转换为字符数组

2.遍历此字符数组,遇到空格,就替换成“%20”

3.将替换后的字符数组再转成字符串,输出

Bug:空格是一个字符,但"%20"是一个字符串,"%20"并不能直接替换空格

所以:

第2步应该细分为:

2.1 定义一个空的StringBuffer

2.2 还是遍历上面的字符数组,将遍历出来的字符用append()方法加入到StringBuffer

     如果遍历出来的是空格,就append()一个"%20"到StringBuffer中,即append("%20");

2.3 将StringBuffer转换成字符串,输出

注:String和StringBuffer他们都可以存储和操作字符串,即包含多个字符的字符串数据。

String类是字符串常量,是不可更改的常量。而StringBuffer是字符串变量,它的对象是可以扩充和修改的。 程序如下:
public class Solution 
    public String replaceSpace(StringBuffer str) 
    	String str1 = str.toString();
    	char[] strArray = str1.toCharArray();
    	StringBuffer strB = new StringBuffer();
    	for(int i = 0; i < strArray.length; i ++)
    		if(strArray[i] == ' ')
    			strB.append("%20");
    		else
        		strB.append(strArray[i]);
    		
    	
    	return strB.toString();
    


以上是关于替换空格算法分析的主要内容,如果未能解决你的问题,请参考以下文章

剑指Offer(书):替换空格

python code practice:KMP算法二分搜索的实现哈希表

[PHP]算法-替换空格的PHP实现

算法入门04替换空格

经典算法题-基础-替换字符串中的空格

算法剑指 Offer 05. 替换空格