-
Notifications
You must be signed in to change notification settings - Fork 0
/
generate_primes_with_digits_in_ascending_order.sf
58 lines (44 loc) · 2.06 KB
/
generate_primes_with_digits_in_ascending_order.sf
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
#!/usr/bin/ruby
# Daniel "Trizen" Șuteu
# Date: 08 April 2022
# https://github.com/trizen
# Generate prime numbers that have all digits in ascending order.
# See also:
# https://rosettacode.org/wiki/Ascending_primes
# OEIS sequences:
# https://oeis.org/A052015 -- Primes with distinct digits in ascending order.
func primes_with_ascending_digits(base = 10) {
var list = []
var digits = @(1..^base -> flip)
var end_digits = digits.grep { .is_coprime(base) }
list << digits.grep { .is_prime && !.is_coprime(base) }...
for k in (0 .. digits.end) {
digits.combinations(k, {|*a|
var v = a.digits2num(base)
end_digits.each {|d|
var n = (v*base + d)
next if ((n >= base) && (a[0] >= d))
list << n if n.is_prime
}
})
}
list.sort
}
var base = 10
var arr = primes_with_ascending_digits(base)
say "There are #{arr.len} ascending primes in base #{base}.\n"
arr.each_slice(10, {|*a|
say a.map { '%9s' % _ }.join(' ')
})
__END__
There are 100 ascending primes in base 10.
2 3 5 7 13 17 19 23 29 37
47 59 67 79 89 127 137 139 149 157
167 179 239 257 269 347 349 359 367 379
389 457 467 479 569 1237 1249 1259 1279 1289
1367 1459 1489 1567 1579 1789 2347 2357 2389 2459
2467 2579 2689 2789 3457 3467 3469 4567 4679 4789
5689 12347 12379 12457 12479 12569 12589 12689 13457 13469
13567 13679 13789 15679 23459 23567 23689 23789 25679 34589
34679 123457 123479 124567 124679 125789 134789 145679 234589 235679
235789 245789 345679 345689 1234789 1235789 1245689 1456789 12356789 23456789