1009. Mersenne Composite N

1009. Mersenne Composite N

sicily prime

题意

原题链接

给一个数k,对小于k的素数,若2^k -1 的值是合数的话,求出它的质因子

code

直接看源码

  
  
  
  
  1. #include <iostream>
  2. #include <vector>
  3. #include <algorithm>
  4. #include <string>
  5. #include <map>
  6. using namespace std;
  7. const int M = 64;
  8. bool is_primes[M + 1];
  9. std::vector<int> primes;
  10. void getPrimes() {
  11. for(int i = 0; i < M + 1; i++) {
  12. is_primes[i] = true;
  13. };
  14. is_primes[0] = false;
  15. is_primes[1] = false;
  16. // is_primes[2] = true;
  17. // is_primes[3] = true;
  18. for(int i = 2; i < M + 1; i++){
  19. if(is_primes[i]) {
  20. for(int j = i * 2; j < M + 1; j += i) {
  21. is_primes[j] = false;
  22. }
  23. }
  24. }
  25. for(int i = 0; i < M + 1; i++) {
  26. if(is_primes[i]) {
  27. primes.push_back(i);
  28. // std::cout << i << " ";
  29. }
  30. }
  31. // std::cout << std::endl;
  32. }
  33. void factor(int prime, std::vector<long long>& pf) {
  34. // note here base variable must be long long type
  35. long long base = 1;
  36. long long mersenne = (base << prime) - 1;
  37. // start from 3
  38. // since mersenne can not divide 2, so we can take the evem number into account
  39. long long i;
  40. for(i = 3; i * i <= mersenne; i += 2) {
  41. while(mersenne % i == 0) {
  42. mersenne /= i;
  43. pf.push_back(i);
  44. }
  45. }
  46. // here don't forget to push back the mersenne
  47. if(mersenne > 1) {
  48. pf.push_back(mersenne);
  49. }
  50. }
  51. void printInfo(const std::vector<long long>& pf, long long mersenne, int prime) {
  52. int size = pf.size();
  53. for(int i = 0; i < size - 1; i++) {
  54. std::cout << pf[i] << " * ";
  55. }
  56. std::cout << pf[size - 1] << " = ";
  57. std::cout << mersenne << " = ( 2 ^ " << prime << " ) - 1";
  58. std::cout << std::endl;
  59. }
  60. void getMersennes(const int minK) {
  61. int size = primes.size();
  62. // ignore 61, but why?
  63. // a tip: since wo can test 61, and it takes a long time to compute and has no result,
  64. // which results in 'Time Limit Exceeded'.
  65. // so here we remove it
  66. for(int i = 0; i < size - 1 && primes[i] <= minK; i++) {
  67. std::vector<long long> pf;
  68. int prime = primes[i];
  69. // factor
  70. factor(prime, pf);
  71. // print info
  72. if(pf.size() > 1) {
  73. // note here base variable must be long long type
  74. long long base = 1;
  75. long long mersenne = (base << prime) - 1;
  76. printInfo(pf, mersenne, prime);
  77. }
  78. pf.clear();
  79. }
  80. }
  81. int main() {
  82. int k;
  83. cin >> k;
  84. //
  85. getPrimes();
  86. //
  87. getMersennes(k);
  88. primes.clear();
  89. return 0;
  90. }

你可能感兴趣的:(C++)