日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

剑指offer:替换空格

發布時間:2025/4/5 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 剑指offer:替换空格 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

替換空格

請實現一個函數,把字符串 s 中的每個空格替換成"%20"。

示例 1:
輸入:s = “We are happy.”
輸出:“We%20are%20happy.”

限制:
0 <= s 的長度 <= 10000

來源:力扣(LeetCode)–替換空格

解題

方法一:內置函數

使用python內置函數 replace()

  • 描述
    str.replace(old, new[, max])
    Python replace() 方法把字符串中的 old(舊字符串) 替換成 new(新字符串),如果指定第三個參數max,則替換不超過 max 次。
  • 參數
    old – 將被替換的子字符串。
    new – 新字符串,用于替換old子字符串。
    max – 可選字符串, 替換不超過 max 次
  • 返回值
    返回字符串中的 old(舊字符串) 替換成 new(新字符串)后生成的新字符串,如果指定第三個參數max,則替換不超過 max 次。
  • class Solution:def replaceSpace(self, s: str) -> str:# 方法一:return s.replace(" ", "%20")

    方法二:遍歷添加

    創建一個新的字符串,依次匹配字符,如果字符為空,則替換并放入新字符串中;如果字符不為空則直接放入新字符串中。

    # python class Solution:def replaceSpace(self, s: str) -> str:# 方法二:str_ = ''for i in s:if i == ' ':i ='%20'str_ = str_ + ireturn str_ // java class Solution {public String replaceSpace(String s) {StringBuilder res = new StringBuilder();for(Character c : s.toCharArray()){if(c == ' ') res.append("%20");else res.append(c);}return res.toString();} }

    復雜度分析:
    時間復雜度:O(N)O(N)O(N)
    空間復雜度:O(N)O(N)O(N),新建字符串使用了線性大小的額外空間。

    Java、python中的字符串

    在 Python 和 Java 等語言中,字符串都被設計成不可變的類型,即無法直接修改字符串的某一位字符,需要新建一個字符串實現。

    添加字符串
    java+、StringBuilder.append()
    python+、list.append() and ’ '.join(list)+適用于較少字符串;list、join()適用于較多字符串的拼接

    參考文章:

  • leetcode題解
  • Java 字符串拼接效率分析及最佳實踐
  • python字符串追加字符_Python字符串追加
  • 總結

    以上是生活随笔為你收集整理的剑指offer:替换空格的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。