如果我有一个数组:array = ["ruby", "code", "library"]
。如何将匹配的/ ^库$ /元素移动到开头。所以阵列看起来像这样:array = [“library”,“ruby”,“code”]红宝石排序阵列 - 移动匹配元素到开始
回答
它可以通过多种方式完成。这是一个
array = ["ruby", "code", "library"]
array.partition { |element| element.match /^library$/ }.flatten
[Enumerable#partition](http://ruby-doc.org/core-2.2.0/Enumerable.html#method-i-partition)可能会保留顺序,但是文档是静音的。 –
def move_to_front(arr, pattern)
mi = matching_indices(arr, pattern)
return arr unless mi
a = arr.dup
mi.reverse_each.with_object([]) { |i,b| b.unshift(a.delete_at(i)) }.concat(a)
end
def matching_indices(arr, pattern)
arr.each_index.select do |i|
case pattern
when Regexp then arr[i] =~ pattern
when Proc then pattern[arr[i]]
else (arr[i] == pattern)
end
end
end
move_to_front ["ruby", "code", "library"], /\Alibrary\z/
#=> ["library", "ruby", "code"]
move_to_front ["ruby", "library", "code", "library"], "library"
#=> ["library", "library", "ruby", "code"]
move_to_front ["ruby", "libraries", "code", "library"], /librar(?:ies|y)/
#=> ["libraries", "library", "ruby", "code"]
move_to_front ["ruby", "libraries", "code", "library"], /\Alibrar/
#=> ["libraries", "library", "ruby", "code"]
move_to_front ["ruby", "libraries", "code", "library"],
->(str) { str =~ /librar(?:ies|y)/ }
#=> ["libraries", "library", "ruby", "code"]
move_to_front ("1".."9").to_a, /[13579]/
#=> ["1", "3", "5", "7", "9", "2", "4", "6", "8"]
move_to_front ("1".."9").to_a, ->(n) { n.to_i.odd? }
#=> ["1", "3", "5", "7", "9", "2", "4", "6", "8"]
move_to_front ("1".."9").to_a, ->(n) { false }
#=> ["1", "2", "3", "4", "5", "6", "7", "8", "9"]
move_to_front ("1".."9").to_a, ->(n) { true }
#=> ["1", "2", "3", "4", "5", "6", "7", "8", "9"]
注:
matching_indices ["ruby", "libraries", "code", "library"], /librar(?:ies|y)/
#=> [1, 3]
的方法move_to_front
保留该移动这些元素的顺序和那些没有移动。
三分一分。
array.inject([]){|a,e| e[/^library/] ? a.unshift(e) : a<<e}
和
array & ["library"] | array
如果数组包含搜索元素多次成为
array.find_all{ |e| e[/^library/] } + array.reject{ |e| e[/^library/] }
如果你不喜欢使用数组变量的两倍还可以这样
[array].map{|a| a & ["library"] | a}.flatten
Th e最后一个:使用grep
array.grep(/library/) + array.grep(/^(?!library)/)
最后一个不会做你认为它的作用。 '/ [^ library] /'会匹配任何包含'l','i','b'等字符的字符串。也许你的意思是'/ ^(?!library)/'? –
@Jordan,我知道这和/ ^(?!库)/会更好,我猜想,但事情是:它的作品,因为它可以让其他字符串,而不是“图书馆” – peter
当然,但它也会匹配'“lliibbrraarryy”'和''yrarbil“'。 –
- 1. 红宝石排序两个阵列
- 2. 重新排序红宝石阵列
- 3. 按数字排序红宝石阵列
- 4. 红宝石阵列从1开始
- 5. 红宝石组合与阵列元素
- 6. 红宝石,排序阵列由
- 7. 红宝石阵列平等
- 8. 添加元素到红宝石阵列返回新阵列
- 9. 红宝石阵列内部
- 10. 红宝石:在阵列
- 11. 红宝石阵列麻烦
- 12. 排序散列红宝石
- 13. 红宝石块到阵列
- 14. 红宝石阵列切片
- 15. 阵列中的红宝石
- 16. 两个红宝石阵列
- 17. 红宝石阵列
- 18. 排序红宝石
- 19. 完成红宝石阵列
- 20. 如何删除一个元素开始以下划线红宝石阵列
- 21. 排序:排序阵列基于多个条件红宝石
- 22. 红宝石气泡排序不排序所有元素
- 23. 如何匹配红宝石
- 24. 红宝石:排序被“连接”到另一个阵列
- 25. 红宝石排序阵列以相反的顺序
- 26. 红宝石阵列适配器
- 27. 红宝石:生成阵列
- 28. 红宝石“bucketize”阵列
- 29. 合并红宝石阵列
- 30. 阵列消除元件根据元素的红宝石
虽然我认为Sean的回答比较好,可以使用'array.sort {| str | str.match(/^library $ /)? 0:1}' –