题目:请实现一个函数,把字符串中的每个空格替换成"%20"。例如输入“We are happy.”,则输出“We%20are%20happy.”。
        应用背景:在网络编程中,如果URL参数中含有特殊字符,如空格、'#'等,可能导致服务器端无法获得正确的参数值。我们需要将这些特殊符号转换成服务器可以识别的字符。转换的规则是在'%'后面跟上ASCII码的两位十六进制的表示。比如空格的ASCII码是32,即十六进制的0x20,因此空格被替换成"%20"。再比如'#'的ASCII码为35,即十六进制的0x23,它在URL中被替换为"%23"。

知识长进:

  1. 为了节省内存,C/C++把常量字符串放到单独的一个内存区域,当几个指针赋值给相同的常量字符串时,他们实际上会指向相同的内存。
  2. 在合并两个数组(包括字符串)时,如果从前往后复制每个数字则需要重复移动数字多次,那么可以逆向思维,考虑从后往前复制,这样子可以减少移动的次数,从而提高效率,但是要注意内存覆盖问题。
  3. 在清楚空格中,清除空格后所得到的字符串要比原先的字符串要短,我们从头到尾进行清楚空格的话就不会覆盖到空格后面的字符,所以我们可以从头开始清除,效率反而比较高。

相比源代码的改进点:因为C/C++中每个字符串都以字符‘\0’作为结尾,所以源代码中if(newLength > length)存在溢出风险,修正为if((newLength+1) > length)。

***********************************************************************************

算法实现:如果从前往后替换字符串,那么保存在空格后面的字符串肯定会被覆盖,那么我们就考虑从后往前进行替换。

  1. 首先遍历原字符串,找出字符串的长度以及其中的空格数量,
  2. 根据原字符串的长度和空格的数量我们可以求出最后新字符串的长度。
  3. 设置两个指针point1和point2分别指向原字符串和新字符串的末尾位置。
  4. 如果point1指向内容不为空格,那么将内容赋值给point2指向的位置,如果point1指向为空格,那么从point2开始赋值“%20”
  5. 直到point1==point2时表明字符串中的所有空格都已经替换完毕。
    #include<cstdio>
    #include<cstring> /*length为字符数组string的总容量*/
    void ReplaceBlank(char string[], int length)
    {
    //特殊输入,鲁棒性
    if (string == nullptr || length <= )
    return; //计算空格的数量
    int i = ;
    int originalLength = ;
    int numberOfBlank = ;
    while (string[i]!='\0') //字符串结尾
    {
    if (string[i] == ' ')
    numberOfBlank++;
    originalLength++;
    ++i;
    }
    /*newLength为把空格替换成'%20'之后的长度*/
    int newLength = originalLength + * numberOfBlank;
    //鲁棒性,自己未考虑到,考虑最后字符串的空格
    if (newLength > (length-))
    return; int indexOfOriginal = originalLength;
    int indexOfNew = newLength;
    while (indexOfNew>indexOfOriginal && indexOfOriginal>=)
    {
    if (string[indexOfOriginal] == ' ')
    {
    //空格,新字符串替换为‘%20’
    string[indexOfNew--] = '';
    string[indexOfNew--] = '';
    string[indexOfNew--] = '%';
    indexOfOriginal--;
    }
    else
    {
    string[indexOfNew--] = string[indexOfOriginal--];
    }
    }
    } // ====================测试代码====================
    void Test(char* testName, char str[], int length, char expected[])
    {
    if (testName != nullptr)
    printf("%s begins: ", testName); ReplaceBlank(str, length); if (expected == nullptr && str == nullptr)
    printf("passed.\n");
    else if (expected == nullptr && str != nullptr)
    printf("failed.\n");
    else if (strcmp(str, expected) == )
    //字符串相等
    printf("passed.\n");
    else
    printf("failed.\n");
    } // 空格在句子中间
    void Test1()
    {
    const int length = ; char str[length] = "hello world";
    Test("Test1", str, length, "hello%20world");
    } // 空格在句子开头
    void Test2()
    {
    const int length = ; char str[length] = " helloworld";
    Test("Test2", str, length, "%20helloworld");
    } // 空格在句子末尾
    void Test3()
    {
    const int length = ; char str[length] = "helloworld ";
    Test("Test3", str, length, "helloworld%20");
    } // 连续有两个空格
    void Test4()
    {
    const int length = ; char str[length] = "hello world";
    Test("Test4", str, length, "hello%20%20world");
    } // 传入nullptr
    void Test5()
    {
    Test("Test5", nullptr, , nullptr);
    } // 传入内容为空的字符串
    void Test6()
    {
    const int length = ; char str[length] = "";
    Test("Test6", str, length, "");
    } //传入内容为一个空格的字符串
    void Test7()
    {
    const int length = ; char str[length] = " ";
    Test("Test7", str, length, "%20");
    } // 传入的字符串没有空格
    void Test8()
    {
    const int length = ; char str[length] = "helloworld";
    Test("Test8", str, length, "helloworld");
    } // 传入的字符串全是空格
    void Test9()
    {
    const int length = ; char str[length] = " ";
    Test("Test9", str, length, "%20%20%20");
    } int main(int argc, char* argv[])
    {
    Test1();
    Test2();
    Test3();
    Test4();
    Test5();
    Test6();
    Test7();
    Test8();
    Test9();
    getchar();
    return ;
    }

《剑指Offer》面试题5-替换空格的更多相关文章

  1. 剑指offer面试题4 替换空格(java)

    注:利用java中stringBuilder,append,length方法很方便的解决字符串问题 /* * 剑指offer 替换空格 * xsf * */ /*开始替换空格的函数,length为原数 ...

  2. 剑指offer面试题4 替换空格(c)

  3. 剑指Offer:面试题4——替换空格(java实现)

    问题描述:请实现一个函数,把字符串中的每个空格替换成"%20". 例如: 输入:"We are happy." 输出:"We%20are%20happ ...

  4. C++版 - 剑指offer 面试题4: 替换空格 题解

    面试题4:替换空格 提交网址: http://www.nowcoder.com/practice/4060ac7e3e404ad1a894ef3e17650423?tpId=13&tqId=1 ...

  5. 剑指Offer编程题2——替换空格

    剑指Offer编程题2——替换空格 题目描述 请实现一个函数,将一个字符串中的每个空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happ ...

  6. 剑指Offer - 九度1510 - 替换空格

    剑指Offer - 九度1510 - 替换空格2013-11-29 20:53 题目描述: 请实现一个函数,将一个字符串中的空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之 ...

  7. 剑指offer第二版-5.替换空格

    面试题5:替换空格 题目要求: 实现一个函数,把字符串中的每个空格都替换成“%20”,已知原位置后面有足够的空余位置,要求改替换过程发生在原来的位置上. 思路: 首先遍历字符串求出串中空格的数量,求出 ...

  8. 剑指offer(2)替换空格

    题目描述 请实现一个函数,将一个字符串中的空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 题目分析 我们如果要替换空格,两步 ...

  9. 剑指offer【02】- 替换空格(Java)

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

  10. 剑指Offer(4)——替换空格

    题目: 请实现一个函数,把字符串中的每个空格替换成"%20".例如输入“We are happy.”,则输出“We%20are%20happy.”. 思路: 如果按照顺序从前往后依 ...

随机推荐

  1. C#程序及批处理中确定windows操作系统的方法

    先上一段代码: private void Form1_Load(object sender, EventArgs e) { OperatingSystem os = Environment.OSVer ...

  2. 201521123031 《Java程序设计》第14周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多数据库相关内容. 2. 书面作业 1. MySQL数据库基本操作 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现自 ...

  3. 201521123070 《JAVA程序设计》第14周学习总结

    1. 本章学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多数据库相关内容. 2. 书面作业 Q1. MySQL数据库基本操作 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现 ...

  4. 才趟过的一个坑,css造成的Validform表单提交按钮点击无效

    最近入手的一个项目,在开发的过程中,遇到了一个以前没遇到过的问题,废了半天的功夫才弄懂原因,留下足迹,警醒后人,下面开始讲故事啦! 在一个昏天暗地的上午,我一个人照常坐在办公室安静的工作中!项目编码已 ...

  5. 安装wampserve之前需要安装vc++2012.

    本人是64位系统下载了wampserver3.0.6之后安装好,启动报错缺少msvcr110.dll. 于是从网上下载了msvcr110.dll放到了windows的syswow64文件夹下,甚至还重 ...

  6. Python接口测试自动化说明及代码实例:含get、post、put、delete等方法

    一.接口说明文档 环境准备: 安装火狐 安装插件: httprequester https://addons.mozilla.org/en-US/firefox/addon/httprequester ...

  7. Lucene第二篇【抽取工具类、索引库优化、分词器、高亮、摘要、排序、多条件搜索】

    对Lucene代码优化 我们再次看回我们上一篇快速入门写过的代码,我来截取一些有代表性的: 以下代码在把数据填充到索引库,和从索引库查询数据的时候,都出现了.是重复代码! Directory dire ...

  8. 详解go语言的array和slice 【二】

    上一篇已经讲解过,array和slice的一些基本用法,使用array和slice时需要注意的地方,特别是slice需要注意的地方比较多.上一篇的最后讲解到创建新的slice时使用第三个索引来限制sl ...

  9. MapReduce中Combiner规约的作用以及不能作为MR标配的原因

    作用:在Mapper端对数据进行Combine归约处理,Combine业务逻辑与Reducer端做的完全相同.处理后的数据再传送到Reducer端,再做一次归约.这样的好处是减少了网络传输的数量.在M ...

  10. NopCommerce添加事务机制

    NopCommerce现在最新版是3.9,不过依然没有事务机制.作为一个商城,我觉得事务也还是很有必要的.以下事务代码以3.9版本作为参考: 首先,IDbContext接口继承IDisposable接 ...