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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

34--替换空格

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

1.問題描述

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

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

2.解題思路

由于每次替換從 1 個字符變成 3 個字符,使用字符數組可方便地進行替換。建立字符數組地長度為 s 的長度的 3 倍,這樣可保證字符數組可以容納所有替換后的字符。

1.獲得 s 的長度 length
2.創建字符數組 array,其長度為 length * 3
3.初始化 size 為 0,size 表示替換后的字符串的長度
4.從左到右遍歷字符串 s

  • 獲得 s 的當前字符 c

  • 如果字符 c 是空格,則令 array[size] = ‘%’,array[size + 1] = ‘2’,array[size + 2] = ‘0’,并將 size 的值加 3

  • 如果字符 c 不是空格,則令 array[size] = c,并將 size 的值加 1

5.遍歷結束之后,size 的值等于替換后的字符串的長度,從 array 的前 size 個字符創建新字符串,并返回新字符串

時間復雜度:O(n) 遍歷字符串 s 一遍。

空間復雜度:O(n) 額外創建字符數組,長度為 s 的長度的 3 倍。

class Solution {public String replaceSpace(String s) {int length = s.length();char[] array = new char[length * 3];int size = 0;for (int i = 0; i < length; i++) {char c = s.charAt(i);if (c == ' ') {array[size++] = '%';array[size++] = '2';array[size++] = '0';} else {array[size++] = c;}}String newStr = new String(array, 0, size);return newStr;} }

總結

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

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