prog.sf 639 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. #!/usr/bin/ruby
  2. # a(n) is the smallest number that requires at least n distinct repdigits to sum.
  3. # https://oeis.org/A336759
  4. # Known terms:
  5. # 1, 10, 21, 309, 2108, 21996
  6. var n = 5
  7. var limit = 21996
  8. var arr = []
  9. for k in (1..9) {
  10. for j in (1..limit.len) {
  11. arr << Num("#{k}"*j)
  12. }
  13. }
  14. arr = arr.grep { _ < limit }.uniq.sort
  15. var seen = Hash()
  16. for k in (1..n) {
  17. arr.combinations(k, {|*a|
  18. var t = a.sum
  19. if (seen.has(t)) {
  20. seen{t} = k if (k < seen{t})
  21. }
  22. else {
  23. seen{t} = k
  24. }
  25. })
  26. }
  27. var z = seen.grep_v{ _ == n }.keys.map{.to_n}.min
  28. say [z, seen{z}]