power_divisors.sf 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. #!/usr/bin/ruby
  2. # Generate the k-th power divisors of n.
  3. # See also:
  4. # https://oeis.org/A035316
  5. # https://oeis.org/A113061
  6. func power_divisors(n, k) {
  7. var d = [1]
  8. for p,e in (n.factor_exp) {
  9. e >= k || next
  10. d << gather {
  11. for j in (k..e `by` k) {
  12. take({|r| d.map {|u| u*r }...}(p**j))
  13. }
  14. }...
  15. }
  16. return d.sort
  17. }
  18. for n in (1..20) {
  19. say "2-power divisors of #{n} = #{power_divisors(n, 2)}"
  20. assert_eq(power_divisors(n, 2).len, 2.power_sigma0(n))
  21. assert_eq(power_divisors(n, 2).sum, 2.power_sigma(n))
  22. assert_eq(power_divisors(n, 3).len, 3.power_sigma0(n))
  23. assert_eq(power_divisors(n, 3).sum, 3.power_sigma(n))
  24. }
  25. __END__
  26. 2-power divisors of 1 = [1]
  27. 2-power divisors of 2 = [1]
  28. 2-power divisors of 3 = [1]
  29. 2-power divisors of 4 = [1, 4]
  30. 2-power divisors of 5 = [1]
  31. 2-power divisors of 6 = [1]
  32. 2-power divisors of 7 = [1]
  33. 2-power divisors of 8 = [1, 4]
  34. 2-power divisors of 9 = [1, 9]
  35. 2-power divisors of 10 = [1]
  36. 2-power divisors of 11 = [1]
  37. 2-power divisors of 12 = [1, 4]
  38. 2-power divisors of 13 = [1]
  39. 2-power divisors of 14 = [1]
  40. 2-power divisors of 15 = [1]
  41. 2-power divisors of 16 = [1, 4, 16]
  42. 2-power divisors of 17 = [1]
  43. 2-power divisors of 18 = [1, 9]
  44. 2-power divisors of 19 = [1]
  45. 2-power divisors of 20 = [1, 4]