str = 'aaa'
(0...1<<str.length).map { |i|
str.chars.map.with_index { |a,b| ((i>>b)&1).zero? ? a : a.upcase }.join
}
# => aaa Aaa aAa AAa aaA AaA aAA AAA
基本思想是n(2 ** n == 1 << n)输出串的功率将为2,其中n = str.length.因此,您可以使用从0到2 ** n-1的索引i作为要升级字母的位域.例如.
000 -> aaa
001 -> aaA
010 -> aAa
011 -> aAA
etc.