[問題] 請教有關於拆字排序的問題
這部分是我練習的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
05/12 23:03, 2F
謝謝您的回覆,所以if 那一個表達式 應該是如果他重新排序後,檢測到裡面已經有相同
排序的值,則直接把輪到的那個字串直接歸到對應的key底下作為value值嗎?
※ 編輯: timeregorge (1.172.87.221), 05/12/2014 23:26:19
→
05/12 23:50, , 3F
05/12 23:50, 3F
→
05/12 23:50, , 4F
05/12 23:50, 4F
→
05/12 23:51, , 5F
05/12 23:51, 5F
→
05/19 00:02, , 6F
05/19 00:02, 6F
Ruby 近期熱門文章
PTT數位生活區 即時熱門文章