算法练习78.URL化——字符串
Posted 一条coding
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法练习78.URL化——字符串相关的知识,希望对你有一定的参考价值。
⭐加入组队刷题,每日一题,每天进步⭐
用例"ds sdfs afs sdfa dfssf asdf " 27 我吐了,居然偷偷加了三个空格在末尾
——leetcode此题热评
前言
哈喽,大家好,我是一条。
糊涂算法,难得糊涂
点击跳转到《糊涂算法》专栏学习java大厂面试必备数据结构和算法知识!
Question
面试题 01.03. URL化
难度:简单
URL化。编写一种方法,将字符串中的空格全部替换为%20。假定该字符串尾部有足够的空间存放新增字符,并且知道字符串的“真实”长度。(注:用Java实现的话,请使用字符数组实现,以便直接在数组上操作。)
示例 1:
输入:"Mr John Smith ", 13 输出:"Mr%20John%20Smith"
示例 2:
输入:" ", 5 输出:"%20%20%20%20%20"
提示:
字符串长度在 [0, 500000] 范围内。
Solution
巧用StringBuilder。
此题更完美的方法是从后向前遍历。
Code
所有
leetcode
代码已同步至github欢迎
star
/**
* @author 一条coding
*/
class Solution {
public String replaceSpaces(String S, int length) {
StringBuilder builder = new StringBuilder();
char[] chars = S.toCharArray();
for (int i = 0; i < length; i++) {
if (chars[i]==' '){
chars[i]='%';
}
builder.append(chars[i]);
}
String s = builder.toString();
return s.replace("%","%20");
}
}
Result
复杂度分析
- 时间复杂度:O(N)
粉丝福利
⭐今天是坚持刷题更文的第78/100天
⭐各位的点赞、关注、收藏、评论、订阅就是一条创作的最大动力
⭐更多数据结构和算法讲解欢迎关注专栏《糊涂算法》
为了回馈各位粉丝,礼尚往来,给大家准备了一些学习资料
以上是关于算法练习78.URL化——字符串的主要内容,如果未能解决你的问题,请参考以下文章
片段(Java) | 机试题+算法思路+考点+代码解析 2023