劍指offer 5 1 替換空格

2021-10-04 09:20:15 字數 949 閱讀 7714

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

示例:借助stringbuilder實現

class

solution

else

newstr.

(s.charat

(i));}

return newstr.

tostring()

;}}

最直觀的做法是從頭到尾掃瞄,遇到空格字元進行替換,同時引出來問題:由於1個字元替換成3個字元,會將空格後面的所有字元都向後移動2個位元組,否則會發生覆蓋。

那麼可以從後向前遍歷,就不必去移動額外字元。這種做法要求事先計算好替換後的字元長度

class

solution

}int newlen = oldlen +

2* spacenum;

int indexnew = newlen -1;

stringbuffer str =

newstringbuffer()

; str.

setlength

(newlen)

;for

(int j = oldlen -

1; j >=

0; j--

)else

}return str.

tostring()

;}}

tostring():返回乙個內容相同的字串

setcharat(int i, char c):將第 i 個**單元設定為 c(可以理解為替換)

insert(int offset, string str)/insert(int offset, char c):在指定位置之前插入字元(串)

delete(int startindex,int endindex):刪除起始位置(含)到結尾位置(不含)之間的字串

劍指offer 替換空格

思路 首先遍歷字串,找出空格的數量countspace,計算變換後的總長為newlength str.length 2 countspace。定義心得字元陣列,長度為newlength 從字串的後面開始複製和替換,如果不是空格,就複製,如果是空格,就變為 20.難點 牛客網上傳入引數是stringb...

劍指offer 替換空格

分析 當看到這個題目時,我們就會想著遍歷字串嘛,遇到空格替換成 20,可是空格只有乙個位元組,20是3個字 節,明顯是不夠的,所以我們遇到把字串整體後移 字串只能存放在陣列中 這樣,空格越多,後邊的字 符移 動的次數也越多。記住 移動的時候一定要移動 0 這樣,如果我們一次移動到位,這樣是不是好一點...

劍指offer 空格替換

空格替換 請實現乙個函式,將乙個字串中的空格替換成 20 例如,當字串為 則經過替換之後的字串為 問題 1 將空格替換成字串,字串將邊長。若要是在原來的字串上做替換,則保證字串後面有足夠的剩餘空間。問題2 若從頭到尾 的方向去替換,則每遇到乙個空格,這個空格後面所有的字元都得向後移動兩位,有的字元會...