→ scwg: 運氣好 str[-1] 可以讀? 演算法 MIN 取左邊時要跳過那個for 05/05 21:43
推 yvb: google 了一下, 那個 str 跟輸入內容不同, 已經被轉換過了. 05/05 21:56
→ yvb: 比方輸入為 "abcd", 則 str 為 "$#a#b#c#d#" 05/05 21:59
→ DiLegend: 對會轉成那樣 我這幾天再想 aaaaa 轉成$#a#a#a#a#a# 05/05 22:11
→ DiLegend: 算到第4個a時 為何不會str[i+p[i]] str[8+4] 然後爆了 05/05 22:15
推 yvb: ??? str[8+4] => '\0', str[8-4] => 'a', for 就跳出了... 05/05 22:28
→ DiLegend: str=[$#a#a#a#a#a#] str[0~11] str[12]不就超出了 05/06 09:47
→ DiLegend: 哪來的 '\0' 啊 05/06 09:47
→ scwg: C 的字串一律用 '\0' 字元標記結束. 寫 "abc" 實際上有四個 05/06 10:02
→ scwg: 字元: 'a' 'b' 'c' '\0' 05/06 10:02
推 yvb: 這實作還是小有問題. 若輸入為 "$", 會發生 str[-1] 的情況. 05/06 21:08
推 yvb: 說得也是. 按其說明, '$'和'#' 實際上是選取不會出現的字符. 05/07 14:13