题解 | #2. 替换空格#
替换空格
http://www.nowcoder.com/practice/0e26e5551f2b489b9f58bc83aa4b6c68
解题思路
- 遍历字符串,找出空格数量
- 新串长度为原始长度+2*空格数量
- 双指针分别指向原串末尾和新串末尾
- 指针前移,复制字母到新串
- 遇到空格,新串向前添加%20
代码
import java.util.*;
public class Solution {
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param s string字符串
* @return string字符串
*/
public String replaceSpace (String s) {
if (s==null){
return null;
}
int spaceCount = 0;
for ( char c : s.toCharArray() ) {
if (c==' '){
spaceCount++;
}
}
char[] array = new char[2*spaceCount+s.length()];
int newIndex = array.length-1;
for (int i = s.length()-1 ; i >= 0 ; i-- ) {
if (s.charAt(i)==' '){
array[newIndex--] = '0';
array[newIndex--] = '2';
array[newIndex--] = '%';
}else {
if (newIndex<0){
break;
}
array[newIndex--] = s.charAt(i);
}
}
String res = new String(array);
return res;
}
}
查看9道真题和解析
阿里云成长空间 749人发布
