首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

字符串替换空格

题目:剑指Offer 05.替换空格 请实现一个函数,把字符串 s 中的每个空格替换成"%20"。 示例 1: 输入:s = "We are happy."...首先扩充数组到每个空格替换成"%20"之后的大小。 然后从后向前替换空格,也就是双指针法,过程如下: i指向新长度的末尾,j指向旧长度的末尾。 ?...s的大小,也就是每个空格替换成"%20"之后的大小 s.resize(s.size() + count * 2); int sNewSize = s.size();...// 从后先前将空格替换为"%20" for (int i = sNewSize - 1, j = sOldSize - 1; j < i; i--, j--) {...拓展 这里也给大家拓展一下字符串和数组有什么差别, 字符串是若干字符组成的有限序列,也可以理解为是一个字符数组,但是很多语言对字符串做了特殊的规定,接下来我来说一说C/C++中的字符串

4.6K30

算法-字符串替换空格

题目: 实现一个函数,把字符串中的每一个空格替换成”%20”。例如输入”We are happy.”,则输出”We%20are%20happy.”。...解题思路: 首先我们需要先想清楚一点,函数就要求输出替换后的结果,没有说是在原数据上替换,还是可以申请内存,创建一个新的字符串?...后者可以让问题变得简单,用比较直接的方式就可以实现一个时间复杂度为O(n)的代码,首先我们先遍历一遍字符串,找到到底有多少个空格以计算出替换后的长度,在上面的例子中,替换前是14,替换后是18,创建一个长度为...18的数组,然后我们只要在从头遍历一次原字符串,没有出现空格就直接复制原字符串的内容,出现空格了就写入”%20”: ?...用直接修改原数据的方法,从后向前替换空格!就酱: ? 这种方法的话,计算替换后的长度就有了一个新的作用,它告诉我们原数据中最后一位放在新数据的哪一位。

2.4K60
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    替换空格

    看到这个题目,我们首先应该想到的是原来一个空格字符,替换之后变成'%'、'2'和'0'这3个字符,因此字符串会变长。如果是在原来的字符串上做替换,那么就有可能覆盖修改在该字符串后面的内存。...我们可以先遍历一次字符串,这样就能统计出字符串空格的总数,并可以由此计算出替换之后的字符串的总长度。每替换一个空格,长度增加2,因此替换以后字符串的长度等于原来的长度加上2乘以空格数目。...此时P1和P2指向同一位置,表明所有空格都已经替换完毕。 ? 注:图中带有阴影的区域表示被移动的字符。(a)把第一个指针指向字符串的末尾,把第二个指针指向替换之后的字符串的末尾。...(b)依次复制字符串的内容,直至第一个指针碰到第一个空格。(c)把第一个空格替换成'%20',把第一个指针向前移动1格,把第二个指针向前移动3格。(d)依次向前复制字符串中的字符,直至碰到空格。...(e)替换字符串中的倒数第二个空格,把第一个指针向前移动1格,把第二个指针向前移动3格。

    2.8K60

    空格替换

    1.空格替换 来源: lintcode-空格替换 问题描述 描述 设计一种方法,将一个字符串中的所有空格替换成 %20 。...你可以假设该字符串有足够的空间来加入新的字符,且你得到的是“真实的”字符长度。 你的程序还需要返回被替换后的字符串的长度。...样例 对于字符串”Mr John Smith”, 长度为 13 替换空格之后,参数中的字符串需要变为”Mr%20John%20Smith”,并且把新长度 17 作为结果返回。...挑战 在原字符串(字符数组)中完成替换,不适用额外空间 解决思路 这道题的暴躁版本呢,就是依次遍历,当遇到空格时,将空格后的字符依次后移两位,这样就腾出了3个空位,插入%20即可。...我们可以拿到当前字符串的长度为11,然后遍历一次后,拿到字符串空格的数量1,将 L + 2 * n = 13就是最终字符串的长度。

    2.3K50

    js去除字符串空格

    使用js去除字符串内所带有空格,有以下三种方法: 1. ...replace正则匹配方法 去除字符串内所有的空格:str = str.replace(/\s*/g,””); 去除字符串内两头的空格:str = str.replace(/^\s*|\s*$/g,””...); 去除字符串内左侧的空格:str = str.replace(/^\s*/,””); 去除字符串内右侧的空格:str = str.replace(/(\s*$)/g,””); 示例: var str...缺陷:只能去除字符串两端的空格,不能去除中间的空格 示例: var str = " 6 6 "; var str_1 = str.trim(); console.log(str_1); //6 6//输出左右侧均无空格...JQ方法:$.trim(str)方法 $.trim() 函数用于去除字符串两端的空白字符。 注意:$.trim()函数会移除字符串开始和末尾处的所有换行符,空格(包括连续的空格)和制表符。

    9.6K50

    js替换html中的字符串,js怎么替换字符串

    js中,可以使用str.replace()方法来替换字符串。replace()方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串;然后返回一个新的字符串。...replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。...说明 字符串 stringObject 的 replace() 方法执行的是查找并替换的操作。...如果它是字符串,那么每个匹配都将由字符串替换。但是 replacement 中的 $ 字符具有特定的含义。如下表所示,它说明从模式匹配得到的字符串将用于替换。...”).className; /*(^|\\s)表示匹配字符串开头或字符串前面的空格,(\\s|$)表示匹配字符串结尾或字符串后面的空格*/ var newClassName = classname.replace

    23.5K20

    字符串——剑指 Offer 05. 替换空格

    替换空格 请实现一个函数,把字符串 s 中的每个空格替换成"%20"。 2 题目示例 示例 1: 输入:s = “We are happy.”...由于每次替换从1个字符变成3个字符,使用字符数组可方便地进行替换。建立字符数组地长度为s的长度的3倍,这样可保证字符数组可以容纳所有替换后的字符。...获得s 的长度 1ength 创建字符数组array,其长度为1ength * 3 初始化size为0,size表示替换后的字符串的长度 从左到右遍历字符串s 获得s的当前字符c 如果字符c是空格...,则令array[size] = ‘%’,array[size + 1] = '2’, array[size + 2] ='0’,并将size的值加3 如果字符C不是空格,则令array[size] =...c,并将size的值加1 遍历结束之后,size的值等于替换后的字符串的长度,从array 的前size个字符创建新字符串,并返回新字符串 复杂性分析 时间复杂度:O(n)O(n)。

    24920

    JS篇(003)-请用 js 去除字符串空格

    答案:replace 正则匹配方法、str.trim()方法、JQ 方法:$.trim(str)方法 解析: 方法一:replace 正则匹配方法 去除字符串内所有的空格:str = str.replace...(/\s\*/g,""); 去除字符串内两头的空格:str = str.replace(/^\s*|\s*\$/g,""); 去除字符串内左侧的空格:str = str.replace(/^\s\*/,...""); 去除字符串内右侧的空格:str = str.replace(/(\s\*\$)/g,""); 示例: var str = " 6 6 "; var str_1 = str.replace(/\...缺陷:只能去除字符串两端的空格,不能去除中间的空格 示例: var str = " 6 6 "; var str_1 = str.trim(); console.log(str_1); //6 6//输出左右侧均无空格...注意:$.trim()函数会移除字符串开始和末尾处的所有换行符,空格(包括连续的空格)和制表符。如果这些空白字符在字符串中间时,它们将被保留,不会被移除。

    6.7K20
    领券