题目:请实现一个函数,把字符串中的每个空格替换成"%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. 201521123101 《Java程序设计》第2周学习总结

    1. 本周学习总结 使用码云保存管理自己的代码: 学习String和Array: 继续对JAVA的探索,希望以后能在编程上更顺畅一些 2. 书面作业 1.使用Eclipse关联jdk源代码(截图),并 ...

  2. 201521123060 《Java程序设计》第12周学习总结

    1.本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多流与文件相关内容. 2.书面作业 将Student对象(属性:int id, String name,int age,double ...

  3. 多线程面试题系列(14):读者写者问题继 读写锁SRWLock

    在第十一篇文章中我们使用事件和一个记录读者个数的变量来解决读者写者问题.问题虽然得到了解决,但代码有点复杂.本篇将介绍一种新方法--读写锁SRWLock来解决这一问题.读写锁在对资源进行保护的同时,还 ...

  4. linux(4) vi编辑/删除、复制、粘贴 /bash shell 环境变量设置/数据流重定向 | 的用法

    一.vi文字处理器1.vi与vimvi:文字处理器vim:程序开发工具2.vi介绍三种模式:一般模式(vi刚进入的,不可编辑),编辑模式(按i后,左下方是insert)和命令行模式(按esc退出,:w ...

  5. 嵌入系统squashfs挂载常见问题总结

    由于squahsfs的一些优点,嵌入系统常常直接使用squashfs作为initrd挂载到/dev/ram,作为rootfs.这里对常见的一些问题进行一些分析. 1. kernel启动出现错误 RAM ...

  6. Spring + Spring MVC + MyBatis 整合

    1.所需要Jar包 ? <!-- Spring3.0.1包 -->   org.springframework.web-3.0.1 系列   <!-- 公共包 -->   sl ...

  7. 利用Docker快速创建Nginx负载均衡节点

    本文版权归博客园和作者吴双本人共同所有 转载和爬虫请注明原文地址 www.cnblogs.com/tdws 一.Self-Host Kestrel 1. 在vs2017中新建dotnet core2. ...

  8. 开源API集成测试工具 Hitchhiker v0.1.3 - 参数化请求

    Hitchhiker 是一款开源的 Restful Api 集成测试工具,你可以轻松部署到本地,和你的team成员一起管理Api. 详细介绍请看: http://www.cnblogs.com/bro ...

  9. 移动端touch事件实现页面弹动--小插件

    动手之前的打盹 说实话真的是好久没有更新博客了,最近一直赶项目,身心疲惫:最关键的是晚上还要回去上一波王者,实在是忙啊! 这周下来,清闲了些许,或许是因为要到国庆的缘故吧,大家都显得无精打采.俗话说的 ...

  10. Qt全局宏和变量

    1.  Qt 全局宏定义 Qt版本号: QT_VERSION :  (major << 16) + (minor << 8) + patch 检测版本号: QT_VERSION ...