替换空格算法分析
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();
以上是关于替换空格算法分析的主要内容,如果未能解决你的问题,请参考以下文章