算法练习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

算法竞赛入门码蹄集进阶塔335题(MT3330-3335)

创建片段而不从 java 代码实例化它

如何在 python 中并行化以下代码片段?

代码练习(二维数组的定义,字符串加减,子元素的创建及绑定,排序算法)

片段事务中的实例化错误