[問題] 請教有關於拆字排序的問題

看板Ruby作者 (vincent)時間10年前 (2014/05/12 22:48), 10年前編輯推噓1(105)
留言6則, 3人參與, 最新討論串1/1
這部分是我練習的code words = ['demo', 'none', 'tied', 'evil', 'dome', 'mode', 'live', 'fowl', 'veil', 'wolf', 'diet', 'vile', 'edit', 'tide', 'flow', 'neon'] result = {} words.each do |word| key = word.split('').sort.join if result.has_key?(key) result[key].push(word) else result[key] = [word] end end result.each do |k, v| puts "---------------" p v end 主要用意是要把每個字串內有四個相同字的字串集合起來 輸出結果是 ["demo", "dome", "mode"] ["neon", "none"] (etc) 其中我比較不解的部分是 if 條件式那邊 key =把字串拆解成個別字元>重新排序>再次加入word內 if的部分result 本身就已經是空的hash了,用has_key?來檢查應該會一直回傳false 因此會直接跳到else的部分把重新排序的部分當作key,換下一個字串的時候一樣再 重新排序,接著再對照,若已經有排序後的值,則直接上把原始排序的值加入作為values 就這樣一直到所有字串都跑完,這樣的流程敘述是對的嗎? 因為有一點不太瞭解這部分的流程!請各位幫我解釋一下,先謝謝各位了! -- ※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 1.172.87.221 ※ 文章網址: http://www.ptt.cc/bbs/Ruby/M.1399906124.A.7E3.html

05/12 23:01, , 1F
其實你的理解大致上已經對了。
05/12 23:01, 1F

05/12 23:03, , 2F
簡單來說就是字母組成相同的字會被放到同一KEY下面。
05/12 23:03, 2F
謝謝您的回覆,所以if 那一個表達式 應該是如果他重新排序後,檢測到裡面已經有相同 排序的值,則直接把輪到的那個字串直接歸到對應的key底下作為value值嗎? ※ 編輯: timeregorge (1.172.87.221), 05/12/2014 23:26:19

05/12 23:50, , 3F
那個if主要功能是將單字推入陣列裡(放在hash裡作為值)
05/12 23:50, 3F

05/12 23:50, , 4F
不過不能直接推入 因為初始值是nil 不是array
05/12 23:50, 4F

05/12 23:51, , 5F
要push進去前要先檢查 不存在要初始化成array(所以是=)
05/12 23:51, 5F

05/19 00:02, , 6F
非常謝謝您的解說!!
05/19 00:02, 6F
文章代碼(AID): #1JSDzCVZ (Ruby)