替换空格

【题目】请实现一个函数,将一个字符串中的空格替换成“%20”。例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

 

1. 时间复杂度为O(n)的算法。

首先,遍历原字符数组,得到空格的个数,乘以2就是新字符数组比原字符数组增加的字符空间。

然后,初始化新字符数组,定义两个指针,p1指向原字符数组的末尾,p2指向新字符数组的末尾。

最后,从后往前移动p1,根据p1指向的元素,给p2指向的位置赋值,同时移动p2。

 

 1 public class Main {
 2 
 3     public static void main(String[] args) {
 4 
 5         String string = "We are happy.";
 6 
 7         Main main = new Main();
 8 
 9         System.out.println(main.process(string));
10 
11     }
12 
13     public String process(String string) {
14 
15         if (null == string) {
16             return null;
17         }
18 
19         char[] chars = string.toCharArray();
20 
21         // 计算空格个数
22         int count = 0;
23         for (int i = 0; i < chars.length; i++) {
24             if (' ' == chars[i]) {
25                 count++;
26             }
27         }
28 
29         char[] charsConv = new char[chars.length + 2 * count];
30 
31         int p2 = charsConv.length - 1;
32         int p1 = chars.length - 1;
33 
34         while (p1 >= 0) {
35 
36             if (' ' == chars[p1]) {
37                 charsConv[p2] = '0';
38                 charsConv[--p2] = '2';
39                 charsConv[--p2] = '%';
40             } else {
41                 charsConv[p2] = chars[p1];
42             }
43 
44             p2--;
45             p1--;
46         }
47 
48         return String.valueOf(charsConv);
49 
50     }
51 }

 

posted @ 2017-12-02 19:06  Mr.van_Gogh  阅读(187)  评论(0编辑  收藏  举报