您的位置:首页 > 编程语言 > Java开发

替换空格算法分析

2016-04-16 10:53 447 查看
请实现一个函数,将一个字符串中的空格替换成“%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();

4000
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();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息