博客
关于我
剑指 Offer 05. 替换空格
阅读量:656 次
发布时间:2019-03-15

本文共 1141 字,大约阅读时间需要 3 分钟。

题目描述

方法一:额外申请空间

思路为了解决空格替换为%20的问题,可以定义一个额外的字符串str。然后遍历原字符串s,当遇到空格时,在str中添加"%20",否则直接将字符添加到str中。

代码

class Solution {public:    string replaceSpace(string s) {        string str;        for (int i = 0; i < s.length(); ++i) {            if (s[i] == ' ') {                str += "%20";            } else {                str += s[i];            }        }        return str;    }};

方法二:原地替换

思路首先统计字符串s中空格的个数。然后在原字符串s上申请额外的空间,空间大小为空格数乘以2。接下来用快慢指针的方法,从字符串末尾向前遍历。当遇到空格时,将该位置及其前两位替换为"%", "2", "0";否则,将字符直接复制到相应位置。

代码

class Solution {public:    string replaceSpace(string s) {        int cnt = 0;        for (int i = 0; i < s.length(); ++i) {            if (s[i] == ' ') {                ++cnt;            }        }        s.resize(s.size() + 2 * cnt);        int i = s.length() - 1, j = s.size() - 1;        while (i < j) {            if (s[i] == ' ') {                s[j] = '0';                s[j-1] = '2';                s[j-2] = '%';                j -= 3;            } else {                s[j] = s[i];                --j;            }            --i;        }        return s;    }};

文章目录

文章目录

目录

  • 方法一:额外申请空间1.1 思路1.2 代码

  • 方法二:原地替换2.1 思路2.2 代码

  • 转载地址:http://mrzmz.baihongyu.com/

    你可能感兴趣的文章
    PHP的json_encode函数应用到微信接口问题(include \uxxxx will create fail)
    查看>>
    PHP的readfile函数和file_get_contents函数错误: Unable to find the wrapper "https"
    查看>>
    php的web路径获取
    查看>>
    php的一些小笔记--字符串
    查看>>
    php的几种运行模式CLI、CGI、FastCGI、mod_php
    查看>>
    php的四大特性八大优势
    查看>>
    RabbitMQ
    查看>>
    PHP的威胁函数与PHP代码审计实战
    查看>>
    PHP的引用举例
    查看>>
    PHP相关代码
    查看>>
    RabbitMQ
    查看>>
    php知识点记录
    查看>>
    PHP知识笔记:CGI, FastCGI, PHP-CGI, PHP-FPM, Spawn-FCGI区别
    查看>>
    PHP第三方登录—OAuth2.0协议
    查看>>
    php筛选js,php如何多条件筛选js代码
    查看>>
    R730服务器做了raid的硬盘,插在R720上面可以用吗?
    查看>>
    PHP类数组式访问(ArrayAccess接口)
    查看>>
    PHP系列:浅谈PHP中isset()和empty() 函数的区别
    查看>>
    PHP索引数组unset的坑-array_values解决方案
    查看>>
    PHP索引数组排序方法整理(冒泡、选择、插入、快速)
    查看>>