# this code works
list = (0..20).to_a
# => [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20]
odd = list.select { |x| x.odd? }
# => [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]
list.reject! { |x| x.odd? }
# => [0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
# but can i emulate this type of functionality with an enumerable method?
set = [1,5,10]
# => [1, 5, 10]
one, five, ten = set
# => [1, 5, 10]
one
# => 1
five
# => 5
ten
# => 10
# ------------------------------------------------
# method I am looking for ?
list = (0..20).to_a
odd, even = list.select_with_reject { |x| x.odd? }
# put the matching items into the first variable
# and the non-matching into the second
回答
当然,可以这样做:
odd, even = list.partition &:odd?
真棒 - 谢谢;有趣的是它显示在可枚举的文档上 - http://ruby-doc.org/core-1.9.2/Enumerable.html但不在数组上? – house9 2013-04-05 23:59:53
@ house9 Enumerable是一个混合类,所以很多类都可以使用它。哈希也使用它们。 – MrDanA 2013-04-06 04:57:02
这是因为它是在'Enumerable'上定义的,而不是在'Array'上定义的。这被称为* inheritance *,是Ruby和许多其他语言的基本概念之一,而不仅仅是面向对象的概念。 – 2013-04-06 07:51:52
odd = []
even = []
list = [1..20]
list.each {|x| x.odd? ? odd << x : even << x }
正如pguardiario所说,partition
方法是最直接的方式。你也可以使用Set#divide
:
require 'set'
list = (1..10).to_a
odd, even = Set.new(list).divide(&:odd?).to_a.map{|x| x.to_a}
你可以尝试以下:
odd,even = (0..20).group_by(&:odd?).values
p odd,even
输出:
[0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20]
[1, 3, 5, 7, 9, 11, 13, 15, 17, 19]
- 1. 两个红宝石阵列
- 2. Perl /红宝石单线阵列操作
- 3. 红宝石阵列注入
- 4. 红宝石枚举列表
- 5. 红宝石阵列
- 6. 阵列阵列,个别阵列红宝石
- 7. 在阵列红宝石
- 8. 红宝石:在阵列
- 9. 红宝石有阵列方法选择!或不?
- 10. 红宝石阵列#选择一个选项哈希匹配
- 11. 集的效率操作VS在红宝石阵列操作
- 12. 阵列与多个条件红宝石
- 13. 红宝石阵列包括一个id
- 14. 供应红宝石阵列选择一个动态块
- 15. 红宝石 - 阵列弄平
- 16. 合并红宝石阵列
- 17. 红宝石嵌套阵列
- 18. 红宝石:从阵列
- 19. 转换阵列,红宝石
- 20. 红宝石阵列内部
- 21. 红宝石发现阵列
- 22. 红宝石从阵列
- 23. 红宝石块到阵列
- 24. 红宝石阵列麻烦
- 25. 阵列中的红宝石
- 26. 完成红宝石阵列
- 27. 红宝石阵列值
- 28. 红宝石阵列范围
- 29. 拼合红宝石阵列
- 30. 红宝石阵列平等
内置的方法很不错,但你不是添加自己的方法到'数组'这将做到这一点? – MrDanA 2013-04-05 23:47:49
是的,我正在考虑猴子修补阵列来添加它 - 看起来像红宝石可能已经内置的东西,但没有看到任何文档 – house9 2013-04-05 23:50:33