LintCode:空格替换

来源:互联网 发布:mysql修改参数为自增 编辑:程序博客网 时间:2024/06/07 22:24

一.题目描述

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

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

样例

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

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


二.解题思路

先算出总共有多少个空格,算出总的字符串长度,然后从尾部开始填充(从头部开始的话会覆盖掉原有的)。

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 hereif (string == null || length <= 0)return 0;int count = 0;for (int i = 0; i < length; i++) {if (string[i] == ' ')count++;}int j = 1;int newLen = length + count * 2;string[newLen] = 0;for (int i = length - 1; i >= 0; i--) {if (string[i] != ' ') {string[newLen - j] = string[i];j++;} else {string[newLen - j] = '0';j++;string[newLen - j] = '2';j++;string[newLen - j] = '%';j++;}}return newLen;}}