获取包含数组的数组的最佳方法是什么,以便在k因子中拆分字符串,其中因子也可能为空? 例如,如果k为3且字符串为
Hello
然后我想要一个返回值如下:
[ ["", "", "Hello"], ["","H","ello"], ["", "He", "llo"], ..., ["H", "e", "llo"], ["H", "el", "lo"], ..., ["Hello","",""] ]
我想在函数中有这个,所以k是参数(对于固定的k,我只写k-1循环)。在红宝石中有一个很好的方法吗?
感谢您的帮助!
答案 0 :(得分:3)
s = "Hello"
k = 3
(0..s.length).to_a.repeated_combination(k - 1)
.map{|a| [0, *a, -1].each_cons(2).map{|i, j| "#{s} "[i...j]}}
结果:
[
["", "", "Hello"],
["", "H", "ello"],
["", "He", "llo"],
["", "Hel", "lo"],
["", "Hell", "o"],
["", "Hello", ""],
["H", "", "ello"],
["H", "e", "llo"],
["H", "el", "lo"],
["H", "ell", "o"],
["H", "ello", ""],
["He", "", "llo"],
["He", "l", "lo"],
["He", "ll", "o"],
["He", "llo", ""],
["Hel", "", "lo"],
["Hel", "l", "o"],
["Hel", "lo", ""],
["Hell", "", "o"],
["Hell", "o", ""],
["Hello", "", ""]
]
答案 1 :(得分:0)
使用递归:
def doit(s, k, b = [], r = [])
case k
when 0
r << b
when 1
doit( [], 0, b + [s], r )
else
(0..s.size).each { |i| doit( s[i..-1], k-1, b + [s[0,i]], r ) }
end
r
end
v = doit('Hello', 3)
#=> [["", "", "Hello"],["", "H", "ello"],["", "He", "llo"],["", "Hel", "lo"],
# ["", "Hell", "o"],["", "Hello", ""],["H", "", "ello"],["H", "e", "llo"],
# ["H", "el", "lo"],["H", "ell", "o"],["H", "ello", ""],["He", "", "llo"],
# ["He", "l", "lo"],["He", "ll", "o"],["He", "llo", ""],["Hel", "", "lo"],
# ["Hel", "l", "o"],["Hel", "lo", ""],["Hell", "", "o"],["Hell", "o", ""],
# ["Hello", "", ""]]