劍指offer 替換空格

2022-08-17 20:36:15 字數 783 閱讀 3587

目錄題目鏈結

劍指offer:替換空格

題目描述這題是很簡單的字串替換問題,最容易想到的就是從前往後依次替換,比較讓人困惑的是所給函式形參中length的作用。

在檢視題目的討論區時,發現從後往前替換會明顯優於從前往後的替換,因為在前者的替換過程中,不需要進行字元的移動,能夠大幅度提公升效率。在下文中給出的是更優的從後往前替換的**。同時,討論區中,大家認為題中的length指的是需返回字串的最大長度,這一要求也在**中有體現。

1.從後往前替換字串

class solution 

// 初始化字串原始長度、字串目標長度、字串中空格數

int oldlength = 0;

int newlength = 0;

int spacenumber = 0;

// 遍歷字串求出上述引數

for (int i = 0; str[i] != '\0'; i++)

}newlength = oldlength + spacenumber * 2;

// 如果目標長度大於給出長度要求則結束函式

if (newlength > length)

// 從後往前處理字串

for (int i = oldlength; i >= 0; i--) else

}}};

劍指offer 替換空格

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

劍指offer 替換空格

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

劍指offer 空格替換

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