作者timeregorge (vincent)
看板Ruby
標題[問題] 請教有關於拆字排序的問題
時間Mon May 12 22:48:42 2014
這部分是我練習的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://webptt.com/m.aspx?n=bbs/Ruby/M.1399906124.A.7E3.html
1F:推 rexkimta:其實你的理解大致上已經對了。 05/12 23:01
2F:→ rexkimta:簡單來說就是字母組成相同的字會被放到同一KEY下面。 05/12 23:03
謝謝您的回覆,所以if 那一個表達式 應該是如果他重新排序後,檢測到裡面已經有相同
排序的值,則直接把輪到的那個字串直接歸到對應的key底下作為value值嗎?
※ 編輯: timeregorge (1.172.87.221), 05/12/2014 23:26:19
3F:→ danny8376:那個if主要功能是將單字推入陣列裡(放在hash裡作為值) 05/12 23:50
4F:→ danny8376:不過不能直接推入 因為初始值是nil 不是array 05/12 23:50
5F:→ danny8376:要push進去前要先檢查 不存在要初始化成array(所以是=) 05/12 23:51
6F:→ timeregorge:非常謝謝您的解說!! 05/19 00:02