10.替换空格

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

题目描述

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

解法1:

class Solution {
public:
  void replaceSpace(char *str,int length) {
        int flag1=0,flag2=0;
      for(int i=0;i<length-1;i++)
      {
          if(str[i]==' ')
              flag1++; 
      }
      for(int i=0;i<length-1+flag1*2;i++) 
      {
           if(str[i]==' ')
           {
               flag2++;
             str[i]='%';
               for(int j=0;j<length-1+(flag2-1)*2-i;j++)
               {
                   str[length+1-j]=str[length-1-j];
               }
               str[i+1]='2';
               str[i+2]='0';
           }  
      }
  }
};

答案错误:您提交的程序没有通过所有的测试用例

case通过率为87.50%


测试用例:

" "

对应输出应该为:


"%20%20%20"


你的输出为:


"%20%2%220"

修改成功:

用时5ms 480如下:

class Solution {
public:
  void replaceSpace(char *str,int length) {
        int flag1=0,flag2=0;
      for(int i=0;i<length-1;i++)
      {
          if(str[i]==' ')
              flag1++; 
      }
      for(int i=0;i<length-1+flag1*2;i++) 
      {
           if(str[i]==' ')
           {
               flag2++;
             str[i]='%';
               for(int j=0;j<length-1+(flag2-1)*2-i;j++)
               {
                   str[length+1+(flag2-1)*2-j]=str[length-1+(flag2-1)*2-j];//从找到的第一个空格开始往右移动数据 也就是涉及到了重复移动
               }
               str[i+1]='2';
               str[i+2]='0';
           }  
      }
  }
};

解法2:

4ms 604k

class Solution {
public:
    void replaceSpace(char *str,int length)
    {
        int count=0;
      //找出所有的空格数
        for(int i=0;i<length;i++)
        {
            if(str[i]==' ')
                count++;
        }
      // 分两步执行 
        for(int i=length-1;i>=0;i--)
        {
            if(str[i]!=' ')
            {
                str[i+2*count]=str[i];
            }
            else
            {
                count--;
                str[i+2*count]='%';//递减2
                str[i+2*count+1]='2';//和后面比较  递减1
                str[i+2*count+2]='0';// 这行操作相当于字母位置对应的移动
            }
        }
    }
};


目录
相关文章
|
Java 调度
java中多线程的基础知识
java中多线程的基础知识
|
Java Linux 测试技术
Java sdk连接fabric网络的谜之报错
Java sdk连接fabric网络的谜之报错
471 0
|
存储 编译器 C语言
C语言学习系列-->第一弹【初识C语言】
C语言学习系列-->第一弹【初识C语言】
228 0
|
存储 Java 数据安全/隐私保护
Java 最常见的面试题:char 和 varchar 的区别是什么?
Java 最常见的面试题:char 和 varchar 的区别是什么?
|
Linux iOS开发 MacOS
Python环境的安装
Python环境的安装
Python环境的安装
|
存储 算法 搜索推荐
C#算法大全(上)
今天有人想让我搞一期C#算法大全。算法就算法,安排上!
|
开发框架 JavaScript 前端开发
Vue.js 3.0搭配.NET Core写一个文件上传组件
Vue.js 3.0搭配.NET Core写一个文件上传组件
354 0
|
域名解析 Web App开发 缓存
一文搞懂常用的网络概念:域名、静态IP和动态IP、域名解析DNS、动态域名解析DDNS
在此之前,我对于网络通讯上的一些基础概念总是含糊其辞,感觉自己知道都又道不出个所以然,总之就是不成体系难以有个整体的把握。因此有了本文,目的是对一些平时颇为关注的网络概念进行总结,描绘出它们的关系,借此也希望能去扫清你的一些障碍,给小伙伴们分享一波。
4906 0
一文搞懂常用的网络概念:域名、静态IP和动态IP、域名解析DNS、动态域名解析DDNS
|
JSON 自然语言处理 算法
ElasticSearch(三)基础语法
ElasticSearch(三)基础语法
167 0