zoukankan      html  css  js  c++  java
  • lintcode 空格替换

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

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

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

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

    分析:

    与剑指offer上一道题目相同,首先算出新字符串的长度:原来的长度+空格的长度*2;其次设置两个指针。分别指向旧字符串与新字符串的最后一位。

    从后往前的思想。复杂度为O(n).

    class Solution {
    public:
        /**
         * @param string: An array of Char
         * @param length: The true length of the string
         * @return: The true length of new string
         */
        int replaceBlank(char string[], int length) {
            // Write your code here
            if(string==NULL||length<=0)
             return 0;
            int originalLength=0;
            int blankNum=0;
            int i=0;
            while(string[i]!='')
            {
                ++originalLength;
                if(string[i]==' ')
                 ++blankNum;
                 
                 ++i;
            }
            int newlength=originalLength+blankNum*2;
            int indexOforiginal=originalLength;
            int indexOfnew=newlength;
            while(indexOforiginal>=0&&indexOfnew>indexOforiginal)
            {
                if(string[indexOforiginal]==' ')
                {
                    string[indexOfnew--]='0';
                    string[indexOfnew--]='2';
                    string[indexOfnew--]='%';
                }
                else
                string[indexOfnew--]=string[indexOforiginal];
                
                --indexOforiginal;
            }
            return newlength;
        }
    };  
    

      

  • 相关阅读:
    ios中的XMPP简介
    iOS项目开发中的目录结构
    ios中怎么样点击背景退出键盘
    ios中怎么处理键盘挡住输入框
    ios中怎么样调节占位文字与字体大小在同一高度
    ios中怎么样设置drawRect方法中绘图的位置
    ios中用drawRect方法绘图的时候设置颜色
    字符串常见操作
    字典、列表、元组
    字符串查看及应用
  • 原文地址:https://www.cnblogs.com/lelelelele/p/6111248.html
Copyright © 2011-2022 走看看