每日一题《剑指offer》字符串篇之替换空格

今日题目链接:替换空格

替换空格

难度:简单

描述

请实现一个函数,将一个字符串s中的每个空格替换成"%20"。

例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy。

数据范围

数据范围:0≤len(s)≤1000

举例

解题思路

对于这个题目,我们首先想到原来的一个空格替换为三个字符,字符串长度会增加,因此,存在以下两种不同的情况:(1)允许创建新的字符串来完成替换。(2)不允许创建新的字符串,在原地完成替换。

第一种情况比较简单。对于第二种情况,有以下两种解法:

方法一 :从头到尾遍历字符串,当遇到空格时,直接利用String类的方法将空格替换成"%20"。时间复杂度为O(n^2)

方法二 :申请一个临时数组,然后再遍历这个字符串的每个字符,如果不是空格就把遍历的字符添加到临时数组中,如果是空格就添加3个字符'%','2','0'分别到临时数组中,最后再把临时数组转化为字符串即可。时间复杂度为O(n)。

实现代码(java)

方法一:

java 复制代码
import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param s string字符串 
     * @return string字符串
     */
    public String replaceSpace (String s) {
        // write code here
        for(int i = 0; i < s.length(); i++){
            if(s.charAt(i)==' '){
                s = s.replace(" ","%20");
            }
        }

        return s;
    }
}

方法二:

ini 复制代码
    public String replaceSpace(String s) {
        int length = s.length();
        char[] array = new char[length * 3];
        int index = 0;
        for (int i = 0; i < length; i++) {
            char c = s.charAt(i);
            if (c == ' ') {
                array[index++] = '%';
                array[index++] = '2';
                array[index++] = '0';
            } else {
                array[index++] = c;
            }
        }
        String newStr = new String(array, 0, index);
        return newStr;
    }
相关推荐
_OP_CHEN3 分钟前
【算法基础篇】(四十三)数论之费马小定理深度解析:从同余性质到乘法逆元
c++·算法·蓝桥杯·数论·acm/icpc
克里斯蒂亚诺更新5 分钟前
vue3使用pinia替代vuex举例
前端·javascript·vue.js
水月wwww6 分钟前
【算法设计】分支限界法
算法·分支限界法
茶猫_12 分钟前
C++学习记录-旧题新做-链表求和
数据结构·c++·学习·算法·leetcode·链表
Benny的老巢15 分钟前
用 Playwright 启动指定 Chrome 账号的本地浏览器, 复用原账号下的cookie信息
前端·chrome
yuniko-n19 分钟前
【牛客面试 TOP 101】链表篇(一)
数据结构·算法·链表·面试·职场和发展
a努力。20 分钟前
京东Java面试被问:双亲委派模型被破坏的场景和原理
java·开发语言·后端·python·面试·linq
2501_9418053127 分钟前
从微服务网关到统一安全治理的互联网工程语法实践与多语言探索
前端·python·算法
源代码•宸28 分钟前
Leetcode—1161. 最大层内元素和【中等】
经验分享·算法·leetcode·golang
寧笙(Lycode)28 分钟前
前端包管理工具——npm、yarn、pnpm详解
前端·npm·node.js