作者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/cn.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