y.pl 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. #!/usr/bin/perl
  2. # Daniel "Trizen" Șuteu
  3. # Date: 10 August 2019
  4. # https://github.com/trizen
  5. # !!! UPDATE !!! a(5) does NOT exist!
  6. # https://www.primepuzzles.net/puzzles/puzz_970.htm
  7. # Various techniques to search for an upper-bound for a(5), which is currently unknwon.
  8. use 5.020;
  9. use ntheory qw(:all);
  10. use experimental qw(signatures);
  11. use List::Util qw(uniq);
  12. my @examples_a4;
  13. {
  14. open my $fh, '<', 'examples_for_a(4).txt';
  15. while (<$fh>) {
  16. while (/(\d+)/g) {
  17. push @examples_a4, $1;
  18. }
  19. }
  20. close $fh;
  21. }
  22. @examples_a4 = uniq(@examples_a4);
  23. say "Total number of a(4) examples: ", scalar(@examples_a4);
  24. sub isok ($p) {
  25. is_prob_prime($p) || return;
  26. my @P = split('0', $p);
  27. my $end = $#P;
  28. foreach my $i (0 .. $end - 1) {
  29. foreach my $j ($i + 1 .. $end) {
  30. is_prob_prime(join('0', @P[$i .. $j])) || return;
  31. }
  32. }
  33. vecall { is_prob_prime($_) } @P;
  34. }
  35. sub check_small_primes {
  36. forprimes {
  37. if (!/0/) {
  38. say "Testing: $_";
  39. foreach my $p (@examples_a4) {
  40. if (isok($p . '0' . $_)) {
  41. die "Found: $p 0 $_";
  42. }
  43. if (isok($_ . '0' . $p)) {
  44. die "Found: $_ 0 $p";
  45. }
  46. }
  47. }
  48. }
  49. 1e6;
  50. }
  51. foreach my $p (@examples_a4) {
  52. isok($p) || die "error for p = $p";
  53. }
  54. #my @primes = grep { $_ != 2 } grep { $_ != 5 } grep { !/0/ } @{primes(1e5)};
  55. my @primes;
  56. my %seen;
  57. sub extract_special_primes ($p) {
  58. if ($p =~ /^30([^0]+)030/) {
  59. push(@primes, $1) if !$seen{$1}++;
  60. }
  61. if ($p =~ /030([^0]+)03\z/) {
  62. push(@primes, $1) if !$seen{$1}++;
  63. }
  64. }
  65. foreach my $p (@examples_a4) {
  66. extract_special_primes($p);
  67. }
  68. #~ forprimes {
  69. #~ if (!/0/) {
  70. #~ if (is_prime('30' . $_) and is_prime($_ . '03') and is_prime("30" . $_ .'03')) {
  71. #~ push(@primes, $_) if !$seen{$_}++;
  72. #~ }
  73. #~ }
  74. #~ } 1e7;
  75. @primes = uniq(3, @primes);
  76. #~ @primes = grep { $_ > 1e10 } @primes;
  77. say "Total number of primes: ", scalar(@primes);
  78. #my @prefix_primes = grep { is_prime("30${_}") } @primes;
  79. #my @suffix_primes = grep { is_prime("${_}03") } @primes;
  80. #~ my @prefix_primes = @special_primes;
  81. #~ my @suffix_primes = @special_primes;
  82. #~ unshift @prefix_primes, 3;
  83. #~ unshift @suffix_primes, 3;
  84. #~ @prefix_primes = uniq(@prefix_primes);
  85. #~ @suffix_primes = uniq(@suffix_primes);
  86. #~ say "Total number of prefix primes: ", scalar(@prefix_primes);
  87. #~ say "Total number of suffix primes: ", scalar(@suffix_primes);
  88. sub generate_from_prefix ($root, $k) {
  89. #~ return if ($root >= 30281172370306703);
  90. if ($k >= 4) {
  91. say "k = $k -> $root";
  92. extract_special_primes($root);
  93. if ($k >= 5) {
  94. die "Found: $root";
  95. }
  96. }
  97. foreach my $p (@primes) {
  98. my $x = join('0', $root, $p);
  99. if (isok($x)) {
  100. __SUB__->($x, $k + 1);
  101. }
  102. }
  103. }
  104. sub generate_from_suffix ($root, $k) {
  105. #~ return if ($root >= 30281172370306703);
  106. if ($k >= 4) {
  107. say "k = $k -> $root";
  108. extract_special_primes($root);
  109. if ($k >= 5) {
  110. die "Found: $root";
  111. }
  112. }
  113. foreach my $p (@primes) {
  114. my $x = join('0', $p, $root);
  115. if (isok($x)) {
  116. __SUB__->($x, $k + 1);
  117. }
  118. }
  119. }
  120. # Prefix/Suffix small prime from 1123
  121. # Tested from p = 2 up to 2159793272 with k = 2
  122. forprimes {
  123. if (!/0/) {
  124. #my $t = "302811723703";
  125. # 30281172370306703
  126. # 3067030332163394903
  127. if (is_prob_prime('30' . $_) and is_prob_prime($_ . '03') and is_prob_prime('30' . $_ . '03')) {
  128. my $t = "30${_}03";
  129. generate_from_prefix($t, 2);
  130. generate_from_suffix($t, 2);
  131. }
  132. #~ if (is_prob_prime($_ . '03')) {
  133. #~ say "Testing: $_";
  134. #~ generate_from_prefix($_ . '03', 1);
  135. #~ }
  136. #~ if (is_prob_prime('30' . $_)) {
  137. #~ generate_from_suffix('30' . $_, 1);
  138. #~ }
  139. }
  140. }
  141. 1, 1e11; # from 22991332421