nth_smooth_number.sf 848 B

1234567891011121314151617181920212223242526272829303132
  1. #!/usr/bin/ruby
  2. # Generate the n-th smooth number that is the product of a given subset of primes.
  3. # See also:
  4. # https://en.wikipedia.org/wiki/Regular_number
  5. # https://en.wikipedia.org/wiki/Smooth_number
  6. func smooth_generator(primes) {
  7. var s = primes.len.of { [1] }
  8. func {
  9. var n = s.map { .first }.min
  10. { |i|
  11. s[i].shift if (s[i][0] == n)
  12. s[i] << (n * primes[i])
  13. } * primes.len
  14. return n
  15. }
  16. }
  17. func nth_smooth_number(n, primes) {
  18. var g = smooth_generator(primes)
  19. (n-1).times { g.run }
  20. g.run
  21. }
  22. say nth_smooth_number( 12, [2,7,13,19])
  23. say nth_smooth_number( 25, [2,5,7,11,13,23,29,31,53,67,71,73,79,89,97,107,113,127,131,137])
  24. say nth_smooth_number(500, [7,19,29,37,41,47,53,59,61,79,83,89,101,103,109,127,131,137,139,157,167,179,181,199,211,229,233,239,241,251])