LeetCode替换空格
LeetCode 替换空格
题目描述
请实现一个函数,把字符串 s 中的每个空格替换成"%20"。
实例 1:
输入:s = "We are happy."
输出:"We%20are%20happy."
一得之见(Java/Python)
使用 Java 的 replaceAll()方法,直接进行替换
/**
* 把字符串 s 中的每个空格替换成"%20"。
*
* @param s 原字符串
* @return 替换后字符串
*/
public static String replaceSpace(String s) {
return s.replaceAll(" ", "%20");
}
使用 Python 的 replace()方法,直接进行替换
def replace_space(s: str) -> str:
"""
把字符串 s 中的每个空格替换成"%20"。
:param s: 原字符串
:return: 替换后字符串
"""
return s.replace(" ", "%20")
他山之石(Java/Python)
由于每次替换从 1 个字符变成 3 个字符,使用字符数组课方便进行替换。简历字符数组的长度为 s 的长度的 3 被,这样可保证字符数组可以容纳所有替换后的字符。
- 获得 s 的长度 length
- 创建字符数组 array,其长度为 length*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)
/**
* 把字符串 s 中的每个空格替换成"%20"。
*
* @param s 原字符串
* @return 替换后字符串
*/
public static String replaceSpaceTwo(String s) {
int sLen = s.length();
char[] sArray = new char[sLen * 3];
int size = 0;
for (int i = 0; i < sLen; i++) {
char c = s.charAt(i);
if (c == ' ') {
sArray[size++] = '%';
sArray[size++] = '2';
sArray[size++] = '0';
} else {
sArray[size++] = c;
}
}
String newStr = new String(sArray, 0, size);
return newStr;
}
- 初始化一个 list,记为 res
- 遍历列表 s 的每个字符 c:
- 当 c 为空格时:向 res 后添加字符串"%20"
- 当 c 不为空格时:向 res 后添加字符串 c
- 将列表 s 转换为字符串并返回。
时间复杂度:O(n) 空间复杂度:O(n)
def replace_space_two(s: str) -> str:
"""
把字符串 s 中的每个空格替换成"%20"。
:param s: 原字符串
:return: 替换后字符串
"""
res = []
for c in s:
if c == ' ':
res.append("%20")
else:
res.append(c)
return "".join(res)
效率对比(Java)
输入:"We are happy"
方法一:3575700ns
方法二:338300ns
效率对比(Python)
输入:"We are happy"
方法一:3300ns
方法二:7600ns
LeetCode替换空格的更多相关文章
- 剑指Offer面试题:3.替换空格
一.题目:替换空格 题目:请实现一个函数,把字符串中的每个空格替换成"%20".例如输入“We are happy.”,则输出“We%20are%20happy.”. 在网络编程中 ...
- 剑指Offer 替换空格
题目描述 请实现一个函数,将一个字符串中的空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 思路: 替换空格,先遍历一遍记 ...
- 剑指Offer:面试题4——替换空格(java实现)
问题描述:请实现一个函数,把字符串中的每个空格替换成"%20". 例如: 输入:"We are happy." 输出:"We%20are%20happ ...
- 【面试题004】c/c++字符串,替换空格
一,c/c++字符串 1.C/C++中每个字符串都以字符’\0‘作为结尾,这样我们就能很方便地找到字符串的最后尾部. 由于这个原因每个字符串都有一个额外的开销,注意字符串越界的问题: 2.C/C+ ...
- 【C语言】字符串替换空格:实现一个函数,把字符串里的空格替换成“%20”
//字符串替换空格:实现一个函数,把字符串里的空格替换成"%20" #include <stdio.h> #include <assert.h> void ...
- 剑指offer-面试题4.替换空格
题目:请实现一个函数,把字符串中的每个空格都替换成"%20".例如输入"We are happy." 则输出"We%20are%20happy.&qu ...
- 剑指offer编程题Java实现——替换空格
题目描述 请实现一个函数,将一个字符串中的空格替换成"%20".例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. package ...
- 【剑指offer】04替换空格,C++实现
0.前言 # 替换空格为字符串部分的题目,剑指offer中字符串系列的文章地址,剑指offer全系列文章地址 1.题目 # 请实现一个函数,将一个字符串中的空格替换成"%20".例 ...
- 剑指offer面试题4 替换空格(java)
注:利用java中stringBuilder,append,length方法很方便的解决字符串问题 /* * 剑指offer 替换空格 * xsf * */ /*开始替换空格的函数,length为原数 ...
随机推荐
- 转:BeanFactory和FactoryBean的区别
一.BeanFactory简介 BeanFacotry是spring中比较原始的Factory.如XMLBeanFactory就是一种典型的BeanFactory.原始的BeanFactory无法支持 ...
- Python import cStringIO ImportError: No module named 'cStringIO'
From Python 3.0 changelog; The StringIO and cStringIO modules are gone. Instead, import the io modul ...
- Element - 日期禁用集合(持续更新)
当前日期之前的日期禁用 <el-date-picker v-model="form.startTime" type="date" placeholder= ...
- supervisor安装
supervisor管理进程,是通过fork/exec的方式将这些被管理的进程当作supervisor的子进程来启动,所以我们只需要将要管理进程的可执行文件的路径添加到supervisor的配置文件中 ...
- docker添加sudo权限
sudo groupadd docker # 添加group sudo gpasswd -a think docker # 添加用户到组 sudo service docker restart n ...
- 12组-Alpha冲刺-2/6
一.基本情况 队名:字节不跳动 组长博客:https://www.cnblogs.com/147258369k/p/15535639.html 小组人数:10人 二.冲刺概况汇报 侯钦凯 过去两天完成 ...
- c#.net 实现短网址的简单方法
短网址,现在很流行了,本文为大家介绍用c#.net实现短网址的方法,有兴趣的朋友,不妨参考下. 短网址,也被叫做网址缩短.网址压缩选装. 这里我们用一个例子来说明其原理吧,假如您带了一包东西去超市购物 ...
- python一对一教程:Computational Problems for Physics chapter 1 Code Listings
作者自我介绍:大爽歌, b站小UP主 ,直播编程+红警三 ,python1对1辅导老师 . 本博客为一对一辅导学生python代码的教案, 获得学生允许公开. 具体辅导内容为<Computati ...
- k8s网络模型与集群通信
在k8s中,我们的应用会以pod的形式被调度到各个node节点上,在设计集群如何处理容器之间的网络时是一个不小的挑战,今天我们会从pod(应用)通信来展开关于k8s网络的讨论. 小作文包含如下内容: ...
- 1组-Alpha冲刺-2/6
一.基本情况 队名:震震带着六菜鸟 组长博客:https://www.cnblogs.com/Klein-Wang/p/15535649.html 小组人数:7人 二.冲刺概况汇报 王业震 过去两天完 ...