【LintCode】 空格替换

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_20801369/article/details/52424901

题目:

设计一种方法,将一个字符串中的所有空格替换成 %20 。你可以假设该字符串有足够的空间来加入新的字符,且你得到的是“真实的”字符长度。

你的程序还需要返回被替换后的字符串的长度。

样例:

对于字符串"Mr John Smith", 长度为 13

替换空格之后,参数中的字符串需要变为"Mr%20John%20Smith",并且把新长度 17 作为结果返回。

求出新的字符数组的长度,将空格的位置替换为%20,这里从后开始遍历,遇到空格就将其替换为%20。这里从后向前遍历的原因是因为其时间效率比从前往后遍历要高(因为从前往后遍历遇到空格时需要将空格后面所有的字符向后移动2个位置,而从后向前则不需要)。

代码如下:


<span style="font-size:18px;">public class Solution {
    /**
     * @param string: An array of Char
     * @param length: The true length of the string
     * @return: The true length of new string
     */
    public int replaceBlank(char[] string, int length) {
        // Write your code here
        int newLength=length;
        int space=0;
        for(int i=0;i<length;i++){
            if(string[i]==' ')
             space++;
        }
        newLength=newLength+space*2;
        int index=newLength;
        for(int i=length-1;i>=0;i--){
            if(string[i]==' '){
                string[--index]='0';
                string[--index]='2';
                string[--index]='%';
            }
            else
            string[--index]=string[i];
        }
        return newLength;
    }
}



</span>


展开阅读全文

没有更多推荐了,返回首页