质数(又称为素数)就是在所有比1大的整数中,除了1和它本身以外,不再有别的约数,这种整数叫做质数或素数。还可以说成质数只有1和它本身两个约数。这终规只是文字上的解释而已。能不能有一个代数式,规定用字母表示的那个数为规定的任何值时,所代入的代数式的值都是质数呢?
所谓质数或称素数,就是一个正整数,除了本身和 1 以外并没有任何其他因子。例如 2,3,5,7 是质数,而 4,6,8,9 则不是,后者称为合成数或合数。从这个观点可将整数分为两种,一种叫质数,一种叫合成数。(有人认为数目字 1 不该称为质数)著名的高斯「唯一分解定理」说,任何一个整数。可以写成一串质数相乘的积。
质数的分布是没有规律的,往往让人莫名其妙。如:101、401、601、701都是质数,但上下面的301(7*43)和901(17*53)却是合数。
有人做过这样的验算:1^2+1+41=43,2^2+2+41=47,3^2+3+41=53……于是就可以有这样一个公式:设一正数为n,则n^2+n+41的值一定是一个质数。这个式子一直到n=39时,都是成立的。但n=40时,其式子就不成立了,因为40^2+40+41=1681=41*41。
说起质数就少不了哥德巴赫猜想,和著名的“1+1”
哥德巴赫猜想 :(Goldbach Conjecture)
内容为“所有的大于2的偶数,都可以表示为两个素数”
这个问题是德国数学家哥德巴赫(C.Goldbach,1690-1764)于1742年6月7日在给大数学家欧拉的信中提出的,所以被称作哥德巴赫猜想。同年6月30日,欧拉在回信中认为这个猜想可能是真的,但他无法证明。从此,这道数学难题引起了几乎所有数学家的注意。哥德巴赫猜想由此成为数学皇冠上一颗可望不可及的“明珠”。“用当代语言来叙述,哥德巴赫猜想有两个内容,第一部分叫做奇数的猜想,第二部分叫做偶数的猜想。奇数的猜想指出,任何一个大于等于7的奇数都是三个素数的和。偶数的猜想是说,大于等于4的偶数一定是两个素数的和。”(引自《哥德巴赫猜想与潘承洞》)
哥德巴赫猜想貌似简单,要证明它却着实不易,成为数学中一个著名的难题。18、19世纪,所有的数论专家对这个猜想的证明都没有作出实质性的推进,直到20世纪才有所突破。直接证明哥德巴赫猜想不行,人们采取了“迂回战术”,就是先考虑把偶数表为两数之和,而每一个数又是若干素数之积。如果把命题"每一个大偶数可以表示成为一个素因子个数不超过a个的数与另一个素因子不超过b个的数之和"记作"a+b",那么哥氏猜想就是要证明"1+1"成立。
1900年,20世纪最伟大的数学家希尔伯特,在国际数学会议上把“哥德巴赫猜想”列为23个数学难题之一。此后,20世纪的数学家们在世界范围内“联手”进攻“哥德巴赫猜想”堡垒,终于取得了辉煌的成果。
到了20世纪20年代,有人开始向它靠近。1920年,挪威数学家布爵用一种古老的筛选法证明,得出了一个结论:每一个比6大的偶数都可以表示为(9+9)。这种缩小包围圈的办法很管用,科学家们于是从(9十9)开始,逐步减少每个数里所含质数因子的个数,直到最后使每个数里都是一个质数为止,这样就证明了“哥德巴赫猜想”。
1920年,挪威的布朗(Brun)证明了 “9+9 ”。
1924年,德国的拉特马赫(Rademacher)证明了“7+7 ”。
1932年,英国的埃斯特曼(Estermann)证明了 “6+6 ”。
1937年,意大利的蕾西(Ricei)先后证明了“5+7 ”, “4+9 ”, “3+15 ”和“2+366 ”。
1938年,苏联的布赫 夕太勃(Byxwrao)证明了“5+5 ”。
1940年,苏联的布赫 夕太勃(Byxwrao)证明了 “4+4 ”。
1948年,匈牙利的瑞尼(Renyi)证明了“1+c ”,其中c是一很大的自然数。
1956年,中国的王元证明了 “3+4 ”。
1957年,中国的王元先后证明了 “3+3 ”和 “2+3 ”。
1962年,中国的潘承洞和苏联的巴尔巴恩(BapoaH)证明了 “1+5 ”, 中国的王元证明了“1+4 ”。
1965年,苏联的布赫 夕太勃(Byxwrao)和小维诺格拉多夫(BHHopappB),及 意大利的朋比利(Bombieri)证明了“1+3 ”。
1966年,中国的陈景润证明了 “1+2 ”[用通俗的话说,就是大偶数=素数+素数*素数或大偶数=素数+素数(注:组成大偶数的素数不可能是偶素数,只能是奇素数。因为在素数中只有一个偶素数,那就是2。)]。
其中“s + t ”问题是指: s个质数的乘积 与t个质数的乘积之和
20世纪的数学家们研究哥德巴赫猜想所采用的主要方法,是筛法、圆法、密率法和三角和法等等高深的数学方法。解决这个猜想的思路,就像“缩小包围圈”一样,逐步逼近最后的结果。
由于陈景润的贡献,人类距离哥德巴赫猜想的最后结果“1+1”仅有一步之遥了。但为了实现这最后的一步,也许还要历经一个漫长的探索过程。有许多数学家认为,要想证明“1+1”,必须通过创造新的数学方法,以往的路很可能都是走不通的
被称为“17世纪最伟大的法国数学家”费尔马,也研究过质数的性质。他发现,设Fn=2^(2^n)+1,则当n分别等于0、1、2、3、4时,Fn分别给出3、5、17、257、65537,都是质数,由于F5太大(F5=4294967297),他没有再往下检测就直接猜测:对于一切自然数,Fn都是质数。但是,就是在F5上出了问题!费尔马死后67年,25岁的瑞士数学家欧拉证明:F5=4294967297=641*6700417,并非质数,而是合数。
更加有趣的是,以后的Fn值,数学家再也没有找到哪个Fn值是质数,全部都是合数。目前由于平方开得较大,因而能够证明的也很少。现在数学家们取得Fn的最大值为:n=1495。这可是个超级天文数字,其位数多达10^10584位,当然它尽管非常之大,但也不是个质数。质数和费尔马开了个大玩笑!
17世纪还有位法国数学家叫梅森,他曾经做过一个猜想:2^p-1代数式,当p是质数时,2^p-1是质数。他验算出了:当p=2、3、5、7、17、19时,所得代数式的值都是质数,后来,欧拉证明p=31时,2^p-1是质数。 p=2,3,5,7时,Mp都是素数,但M11=2047=23×89不是素数。
还剩下p=67、127、257三个梅森数,由于太大,长期没有人去验证。梅森去世250年后,美国数学家科勒证明,2^67-1=193707721*761838257287,是一个合数。这是第九个梅森数。20世纪,人们先后证明:第10个梅森数是质数,第11个梅森数是合数。质数排列得这样杂乱无章,也给人们寻找质数规律造成了困难。
现在,数学家找到的最大的梅森数是一个有9808357位的数:2^32582657-1。数学虽然可以找到很大的质数,但质数的规律还是无法循通。
30000以内的质数表
2 3 5 7 11 13 17 19 23 29 31 37 41 43 47
53 59 61 67 71 73 79 83 89 97 101 103 107 109 113
127 131 137 139 149 151 157 163 167 173 179 181 191 193 197
199 211 223 227 229 233 239 241 251 257 263 269 271 277 281
283 293 307 311 313 317 331 337 347 349 353 359 367 373 379
383 389 397 401 409 419 421 431 433 439 443 449 457 461 463
467 479 487 491 499 503 509 521 523 541 547 557 563 569 571
577 587 593 599 601 607 613 617 619 631 641 643 647 653 659
661 673 677 683 691 701 709 719 727 733 739 743 751 757 761
769 773 787 797 809 811 821 823 827 829 839 853 857 859 863
877 881 883 887 907 911 919 929 937 941 947 953 967 971 977
983 991 997 1009 1013 1019 1021 1031 1033 1039 1049 1051 1061 1063 1069
1087 1091 1093 1097 1103 1109 1117 1123 1129 1151 1153 1163 1171 1181 1187
1193 1201 1213 1217 1223 1229 1231 1237 1249 1259 1277 1279 1283 1289 1291
1297 1301 1303 1307 1319 1321 1327 1361 1367 1373 1381 1399 1409 1423 1427
1429 1433 1439 1447 1451 1453 1459 1471 1481 1483 1487 1489 1493 1499 1511
1523 1531 1543 1549 1553 1559 1567 1571 1579 1583 1597 1601 1607 1609 1613
1619 1621 1627 1637 1657 1663 1667 1669 1693 1697 1699 1709 1721 1723 1733
1741 1747 1753 1759 1777 1783 1787 1789 1801 1811 1823 1831 1847 1861 1867
1871 1873 1877 1879 1889 1901 1907 1913 1931 1933 1949 1951 1973 1979 1987
1993 1997 1999 2003 2011 2017 2027 2029 2039 2053 2063 2069 2081 2083 2087
2089 2099 2111 2113 2129 2131 2137 2141 2143 2153 2161 2179 2203 2207 2213
2221 2237 2239 2243 2251 2267 2269 2273 2281 2287 2293 2297 2309 2311 2333
2339 2341 2347 2351 2357 2371 2377 2381 2383 2389 2393 2399 2411 2417 2423
2437 2441 2447 2459 2467 2473 2477 2503 2521 2531 2539 2543 2549 2551 2557
2579 2591 2593 2609 2617 2621 2633 2647 2657 2659 2663 2671 2677 2683 2687
2689 2693 2699 2707 2711 2713 2719 2729 2731 2741 2749 2753 2767 2777 2789
2791 2797 2801 2803 2819 2833 2837 2843 2851 2857 2861 2879 2887 2897 2903
2909 2917 2927 2939 2953 2957 2963 2969 2971 2999 3001 3011 3019 3023 3037
3041 3049 3061 3067 3079 3083 3089 3109 3119 3121 3137 3163 3167 3169 3181
3187 3191 3203 3209 3217 3221 3229 3251 3253 3257 3259 3271 3299 3301 3307
3313 3319 3323 3329 3331 3343 3347 3359 3361 3371 3373 3389 3391 3407 3413
3433 3449 3457 3461 3463 3467 3469 3491 3499 3511 3517 3527 3529 3533 3539
3541 3547 3557 3559 3571 3581 3583 3593 3607 3613 3617 3623 3631 3637 3643
3659 3671 3673 3677 3691 3697 3701 3709 3719 3727 3733 3739 3761 3767 3769
3779 3793 3797 3803 3821 3823 3833 3847 3851 3853 3863 3877 3881 3889 3907
3911 3917 3919 3923 3929 3931 3943 3947 3967 3989 4001 4003 4007 4013 4019
4021 4027 4049 4051 4057 4073 4079 4091 4093 4099 4111 4127 4129 4133 4139
4153 4157 4159 4177 4201 4211 4217 4219 4229 4231 4241 4243 4253 4259 4261
4271 4273 4283 4289 4297 4327 4337 4339 4349 4357 4363 4373 4391 4397 4409
4421 4423 4441 4447 4451 4457 4463 4481 4483 4493 4507 4513 4517 4519 4523
4547 4549 4561 4567 4583 4591 4597 4603 4621 4637 4639 4643 4649 4651 4657
4663 4673 4679 4691 4703 4721 4723 4729 4733 4751 4759 4783 4787 4789 4793
4799 4801 4813 4817 4831 4861 4871 4877 4889 4903 4909 4919 4931 4933 4937
4943 4951 4957 4967 4969 4973 4987 4993 4999 5003 5009 5011 5021 5023 5039
5051 5059 5077 5081 5087 5099 5101 5107 5113 5119 5147 5153 5167 5171 5179
5189 5197 5209 5227 5231 5233 5237 5261 5273 5279 5281 5297 5303 5309 5323
5333 5347 5351 5381 5387 5393 5399 5407 5413 5417 5419 5431 5437 5441 5443
5449 5471 5477 5479 5483 5501 5503 5507 5519 5521 5527 5531 5557 5563 5569
5573 5581 5591 5623 5639 5641 5647 5651 5653 5657 5659 5669 5683 5689 5693
5701 5711 5717 5737 5741 5743 5749 5779 5783 5791 5801 5807 5813 5821 5827
5839 5843 5849 5851 5857 5861 5867 5869 5879 5881 5897 5903 5923 5927 5939
5953 5981 5987 6007 6011 6029 6037 6043 6047 6053 6067 6073 6079 6089 6091
6101 6113 6121 6131 6133 6143 6151 6163 6173 6197 6199 6203 6211 6217 6221
6229 6247 6257 6263 6269 6271 6277 6287 6299 6301 6311 6317 6323 6329 6337
6343 6353 6359 6361 6367 6373 6379 6389 6397 6421 6427 6449 6451 6469 6473
6481 6491 6521 6529 6547 6551 6553 6563 6569 6571 6577 6581 6599 6607 6619
6637 6653 6659 6661 6673 6679 6689 6691 6701 6703 6709 6719 6733 6737 6761
6763 6779 6781 6791 6793 6803 6823 6827 6829 6833 6841 6857 6863 6869 6871
6883 6899 6907 6911 6917 6947 6949 6959 6961 6967 6971 6977 6983 6991 6997
7001 7013 7019 7027 7039 7043 7057 7069 7079 7103 7109 7121 7127 7129 7151
7159 7177 7187 7193 7207 7211 7213 7219 7229 7237 7243 7247 7253 7283 7297
7307 7309 7321 7331 7333 7349 7351 7369 7393 7411 7417 7433 7451 7457 7459
7477 7481 7487 7489 7499 7507 7517 7523 7529 7537 7541 7547 7549 7559 7561
7573 7577 7583 7589 7591 7603 7607 7621 7639 7643 7649 7669 7673 7681 7687
7691 7699 7703 7717 7723 7727 7741 7753 7757 7759 7789 7793 7817 7823 7829
7841 7853 7867 7873 7877 7879 7883 7901 7907 7919 7927 7933 7937 7949 7951
7963 7993 8009 8011 8017 8039 8053 8059 8069 8081 8087 8089 8093 8101 8111
8117 8123 8147 8161 8167 8171 8179 8191 8209 8219 8221 8231 8233 8237 8243
8263 8269 8273 8287 8291 8293 8297 8311 8317 8329 8353 8363 8369 8377 8387
8389 8419 8423 8429 8431 8443 8447 8461 8467 8501 8513 8521 8527 8537 8539
8543 8563 8573 8581 8597 8599 8609 8623 8627 8629 8641 8647 8663 8669 8677
8681 8689 8693 8699 8707 8713 8719 8731 8737 8741 8747 8753 8761 8779 8783
8803 8807 8819 8821 8831 8837 8839 8849 8861 8863 8867 8887 8893 8923 8929
8933 8941 8951 8963 8969 8971 8999 9001 9007 9011 9013 9029 9041 9043 9049
9059 9067 9091 9103 9109 9127 9133 9137 9151 9157 9161 9173 9181 9187 9199
9203 9209 9221 9227 9239 9241 9257 9277 9281 9283 9293 9311 9319 9323 9337
9341 9343 9349 9371 9377 9391 9397 9403 9413 9419 9421 9431 9433 9437 9439
9461 9463 9467 9473 9479 9491 9497 9511 9521 9533 9539 9547 9551 9587 9601
9613 9619 9623 9629 9631 9643 9649 9661 9677 9679 9689 9697 9719 9721 9733
9739 9743 9749 9767 9769 9781 9787 9791 9803 9811 9817 9829 9833 9839 9851
9857 9859 9871 9883 9887 9901 9907 9923 9929 9931 9941 9949 9967 9973 10007
10009 10037 10039 10061 10067 10069 10079 10091 10093 10099 10103 10111 10133 10139 10141
10151 10159 10163 10169 10177 10181 10193 10211 10223 10243 10247 10253 10259 10267 10271
10273 10289 10301 10303 10313 10321 10331 10333 10337 10343 10357 10369 10391 10399 10427
10429 10433 10453 10457 10459 10463 10477 10487 10499 10501 10513 10529 10531 10559 10567
10589 10597 10601 10607 10613 10627 10631 10639 10651 10657 10663 10667 10687 10691 10709
10711 10723 10729 10733 10739 10753 10771 10781 10789 10799 10831 10837 10847 10853 10859
10861 10867 10883 10889 10891 10903 10909 10937 10939 10949 10957 10973 10979 10987 10993
11003 11027 11047 11057 11059 11069 11071 11083 11087 11093 11113 11117 11119 11131 11149
11159 11161 11171 11173 11177 11197 11213 11239 11243 11251 11257 11261 11273 11279 11287
11299 11311 11317 11321 11329 11351 11353 11369 11383 11393 11399 11411 11423 11437 11443
11447 11467 11471 11483 11489 11491 11497 11503 11519 11527 11549 11551 11579 11587 11593
11597 11617 11621 11633 11657 11677 11681 11689 11699 11701 11717 11719 11731 11743 11777
11779 11783 11789 11801 11807 11813 11821 11827 11831 11833 11839 11863 11867 11887 11897
11903 11909 11923 11927 11933 11939 11941 11953 11959 11969 11971 11981 11987 12007 12011
12037 12041 12043 12049 12071 12073 12097 12101 12107 12109 12113 12119 12143 12149 12157
12161 12163 12197 12203 12211 12227 12239 12241 12251 12253 12263 12269 12277 12281 12289
12301 12323 12329 12343 12347 12373 12377 12379 12391 12401 12409 12413 12421 12433 12437
12451 12457 12473 12479 12487 12491 12497 12503 12511 12517 12527 12539 12541 12547 12553
12569 12577 12583 12589 12601 12611 12613 12619 12637 12641 12647 12653 12659 12671 12689
12697 12703 12713 12721 12739 12743 12757 12763 12781 12791 12799 12809 12821 12823 12829
12841 12853 12889 12893 12899 12907 12911 12917 12919 12923 12941 12953 12959 12967 12973
12979 12983 13001 13003 13007 13009 13033 13037 13043 13049 13063 13093 13099 13103 13109
13121 13127 13147 13151 13159 13163 13171 13177 13183 13187 13217 13219 13229 13241 13249
13259 13267 13291 13297 13309 13313 13327 13331 13337 13339 13367 13381 13397 13399 13411
13417 13421 13441 13451 13457 13463 13469 13477 13487 13499 13513 13523 13537 13553 13567
13577 13591 13597 13613 13619 13627 13633 13649 13669 13679 13681 13687 13691 13693 13697
13709 13711 13721 13723 13729 13751 13757 13759 13763 13781 13789 13799 13807 13829 13831
13841 13859 13873 13877 13879 13883 13901 13903 13907 13913 13921 13931 13933 13963 13967
13997 13999 14009 14011 14029 14033 14051 14057 14071 14081 14083 14087 14107 14143 14149
14153 14159 14173 14177 14197 14207 14221 14243 14249 14251 14281 14293 14303 14321 14323
14327 14341 14347 14369 14387 14389 14401 14407 14411 14419 14423 14431 14437 14447 14449
14461 14479 14489 14503 14519 14533 14537 14543 14549 14551 14557 14561 14563 14591 14593
14621 14627 14629 14633 14639 14653 14657 14669 14683 14699 14713 14717 14723 14731 14737
14741 14747 14753 14759 14767 14771 14779 14783 14797 14813 14821 14827 14831 14843 14851
14867 14869 14879 14887 14891 14897 14923 14929 14939 14947 14951 14957 14969 14983 15013
15017 15031 15053 15061 15073 15077 15083 15091 15101 15107 15121 15131 15137 15139 15149
15161 15173 15187 15193 15199 15217 15227 15233 15241 15259 15263 15269 15271 15277 15287
15289 15299 15307 15313 15319 15329 15331 15349 15359 15361 15373 15377 15383 15391 15401
15413 15427 15439 15443 15451 15461 15467 15473 15493 15497 15511 15527 15541 15551 15559
15569 15581 15583 15601 15607 15619 15629 15641 15643 15647 15649 15661 15667 15671 15679
15683 15727 15731 15733 15737 15739 15749 15761 15767 15773 15787 15791 15797 15803 15809
15817 15823 15859 15877 15881 15887 15889 15901 15907 15913 15919 15923 15937 15959 15971
15973 15991 16001 16007 16033 16057 16061 16063 16067 16069 16073 16087 16091 16097 16103
16111 16127 16139 16141 16183 16187 16189 16193 16217 16223 16229 16231 16249 16253 16267
16273 16301 16319 16333 16339 16349 16361 16363 16369 16381 16411 16417 16421 16427 16433
16447 16451 16453 16477 16481 16487 16493 16519 16529 16547 16553 16561 16567 16573 16603
16607 16619 16631 16633 16649 16651 16657 16661 16673 16691 16693 16699 16703 16729 16741
16747 16759 16763 16787 16811 16823 16829 16831 16843 16871 16879 16883 16889 16901 16903
16921 16927 16931 16937 16943 16963 16979 16981 16987 16993 17011 17021 17027 17029 17033
17041 17047 17053 17077 17093 17099 17107 17117 17123 17137 17159 17167 17183 17189 17191
17203 17207 17209 17231 17239 17257 17291 17293 17299 17317 17321 17327 17333 17341 17351
17359 17377 17383 17387 17389 17393 17401 17417 17419 17431 17443 17449 17467 17471 17477
17483 17489 17491 17497 17509 17519 17539 17551 17569 17573 17579 17581 17597 17599 17609
17623 17627 17657 17659 17669 17681 17683 17707 17713 17729 17737 17747 17749 17761 17783
17789 17791 17807 17827 17837 17839 17851 17863 17881 17891 17903 17909 17911 17921 17923
17929 17939 17957 17959 17971 17977 17981 17987 17989 18013 18041 18043 18047 18049 18059
18061 18077 18089 18097 18119 18121 18127 18131 18133 18143 18149 18169 18181 18191 18199
18211 18217 18223 18229 18233 18251 18253 18257 18269 18287 18289 18301 18307 18311 18313
18329 18341 18353 18367 18371 18379 18397 18401 18413 18427 18433 18439 18443 18451 18457
18461 18481 18493 18503 18517 18521 18523 18539 18541 18553 18583 18587 18593 18617 18637
18661 18671 18679 18691 18701 18713 18719 18731 18743 18749 18757 18773 18787 18793 18797
18803 18839 18859 18869 18899 18911 18913 18917 18919 18947 18959 18973 18979 19001 19009
19013 19031 19037 19051 19069 19073 19079 19081 19087 19121 19139 19141 19157 19163 19181
19183 19207 19211 19213 19219 19231 19237 19249 19259 19267 19273 19289 19301 19309 19319
19333 19373 19379 19381 19387 19391 19403 19417 19421 19423 19427 19429 19433 19441 19447
19457 19463 19469 19471 19477 19483 19489 19501 19507 19531 19541 19543 19553 19559 19571
19577 19583 19597 19603 19609 19661 19681 19687 19697 19699 19709 19717 19727 19739 19751
19753 19759 19763 19777 19793 19801 19813 19819 19841 19843 19853 19861 19867 19889 19891
19913 19919 19927 19937 19949 19961 19963 19973 19979 19991 19993 19997 20011 20021 20023
20029 20047 20051 20063 20071 20089 20101 20107 20113 20117 20123 20129 20143 20147 20149
20161 20173 20177 20183 20201 20219 20231 20233 20249 20261 20269 20287 20297 20323 20327
20333 20341 20347 20353 20357 20359 20369 20389 20393 20399 20407 20411 20431 20441 20443
20477 20479 20483 20507 20509 20521 20533 20543 20549 20551 20563 20593 20599 20611 20627
20639 20641 20663 20681 20693 20707 20717 20719 20731 20743 20747 20749 20753 20759 20771
20773 20789 20807 20809 20849 20857 20873 20879 20887 20897 20899 20903 20921 20929 20939
20947 20959 20963 20981 20983 21001 21011 21013 21017 21019 21023 21031 21059 21061 21067
21089 21101 21107 21121 21139 21143 21149 21157 21163 21169 21179 21187 21191 21193 21211
21221 21227 21247 21269 21277 21283 21313 21317 21319 21323 21341 21347 21377 21379 21383
21391 21397 21401 21407 21419 21433 21467 21481 21487 21491 21493 21499 21503 21517 21521
21523 21529 21557 21559 21563 21569 21577 21587 21589 21599 21601 21611 21613 21617 21647
21649 21661 21673 21683 21701 21713 21727 21737 21739 21751 21757 21767 21773 21787 21799
21803 21817 21821 21839 21841 21851 21859 21863 21871 21881 21893 21911 21929 21937 21943
21961 21977 21991 21997 22003 22013 22027 22031 22037 22039 22051 22063 22067 22073 22079
22091 22093 22109 22111 22123 22129 22133 22147 22153 22157 22159 22171 22189 22193 22229
22247 22259 22271 22273 22277 22279 22283 22291 22303 22307 22343 22349 22367 22369 22381
22391 22397 22409 22433 22441 22447 22453 22469 22481 22483 22501 22511 22531 22541 22543
22549 22567 22571 22573 22613 22619 22621 22637 22639 22643 22651 22669 22679 22691 22697
22699 22709 22717 22721 22727 22739 22741 22751 22769 22777 22783 22787 22807 22811 22817
22853 22859 22861 22871 22877 22901 22907 22921 22937 22943 22961 22963 22973 22993 23003
23011 23017 23021 23027 23029 23039 23041 23053 23057 23059 23063 23071 23081 23087 23099
23117 23131 23143 23159 23167 23173 23189 23197 23201 23203 23209 23227 23251 23269 23279
23291 23293 23297 23311 23321 23327 23333 23339 23357 23369 23371 23399 23417 23431 23447
23459 23473 23497 23509 23531 23537 23539 23549 23557 23561 23563 23567 23581 23593 23599
23603 23609 23623 23627 23629 23633 23663 23669 23671 23677 23687 23689 23719 23741 23743
23747 23753 23761 23767 23773 23789 23801 23813 23819 23827 23831 23833 23857 23869 23873
23879 23887 23893 23899 23909 23911 23917 23929 23957 23971 23977 23981 23993 24001 24007
24019 24023 24029 24043 24049 24061 24071 24077 24083 24091 24097 24103 24107 24109 24113
24121 24133 24137 24151 24169 24179 24181 24197 24203 24223 24229 24239 24247 24251 24281
24317 24329 24337 24359 24371 24373 24379 24391 24407 24413 24419 24421 24439 24443 24469
24473 24481 24499 24509 24517 24527 24533 24547 24551 24571 24593 24611 24623 24631 24659
24671 24677 24683 24691 24697 24709 24733 24749 24763 24767 24781 24793 24799 24809 24821
24841 24847 24851 24859 24877 24889 24907 24917 24919 24923 24943 24953 24967 24971 24977
24979 24989 25013 25031 25033 25037 25057 25073 25087 25097 25111 25117 25121 25127 25147
25153 25163 25169 25171 25183 25189 25219 25229 25237 25243 25247 25253 25261 25301 25303
25307 25309 25321 25339 25343 25349 25357 25367 25373 25391 25409 25411 25423 25439 25447
25453 25457 25463 25469 25471 25523 25537 25541 25561 25577 25579 25583 25589 25601 25603
25609 25621 25633 25639 25643 25657 25667 25673 25679 25693 25703 25717 25733 25741 25747
25759 25763 25771 25793 25799 25801 25819 25841 25847 25849 25867 25873 25889 25903 25913
25919 25931 25933 25939 25943 25951 25969 25981 25997 25999 26003 26017 26021 26029 26041
26053 26083 26099 26107 26111 26113 26119 26141 26153 26161 26171 26177 26183 26189 26203
26209 26227 26237 26249 26251 26261 26263 26267 26293 26297 26309 26317 26321 26339 26347
26357 26371 26387 26393 26399 26407 26417 26423 26431 26437 26449 26459 26479 26489 26497
26501 26513 26539 26557 26561 26573 26591 26597 26627 26633 26641 26647 26669 26681 26683
26687 26693 26699 26701 26711 26713 26717 26723 26729 26731 26737 26759 26777 26783 26801
26813 26821 26833 26839 26849 26861 26863 26879 26881 26891 26893 26903 26921 26927 26947
26951 26953 26959 26981 26987 26993 27011 27017 27031 27043 27059 27061 27067 27073 27077
27091 27103 27107 27109 27127 27143 27179 27191 27197 27211 27239 27241 27253 27259 27271
27277 27281 27283 27299 27329 27337 27361 27367 27397 27407 27409 27427 27431 27437 27449
27457 27479 27481 27487 27509 27527 27529 27539 27541 27551 27581 27583 27611 27617 27631
27647 27653 27673 27689 27691 27697 27701 27733 27737 27739 27743 27749 27751 27763 27767
27773 27779 27791 27793 27799 27803 27809 27817 27823 27827 27847 27851 27883 27893 27901
27917 27919 27941 27943 27947 27953 27961 27967 27983 27997 28001 28019 28027 28031 28051
28057 28069 28081 28087 28097 28099 28109 28111 28123 28151 28163 28181 28183 28201 28211
28219 28229 28277 28279 28283 28289 28297 28307 28309 28319 28349 28351 28387 28393 28403
28409 28411 28429 28433 28439 28447 28463 28477 28493 28499 28513 28517 28537 28541 28547
28549 28559 28571 28573 28579 28591 28597 28603 28607 28619 28621 28627 28631 28643 28649
28657 28661 28663 28669 28687 28697 28703 28711 28723 28729 28751 28753 28759 28771 28789
28793 28807 28813 28817 28837 28843 28859 28867 28871 28879 28901 28909 28921 28927 28933
28949 28961 28979 29009 29017 29021 29023 29027 29033 29059 29063 29077 29101 29123 29129
29131 29137 29147 29153 29167 29173 29179 29191 29201 29207 29209 29221 29231 29243 29251
29269 29287 29297 29303 29311 29327 29333 29339 29347 29363 29383 29387 29389 29399 29401
29411 29423 29429 29437 29443 29453 29473 29483 29501 29527 29531 29537 29567 29569 29573
29581 29587 29599 29611 29629 29633 29641 29663 29669 29671 29683 29717 29723 29741 29753
29759 29761 29789 29803 29819 29833 29837 29851 29863 29867 29873 29879 29881 29917 29921
29927 29947 29959 29983 29989
研究发现质数除2以外都是奇数,而奇数除了【奇数*奇数】(或再加“*奇数”)都是质数。那么用计算机先把【奇数*奇数】(或再加“*奇数”)(比如9,15,21,25,27,33,35,39……)都求出来,再找奇数中上面没提到的那些数,那些数就是素数。
人们找出的几个超大质数中有遗漏,那么就可以用此方法求出那些遗漏的数,不过需要很长时间!
这对于“孪生素数”有帮助!
上面这个算法比较垃圾,对于求很大的素数效率低下,这个很大的素数可以用概率算法求。
有近似公式: x 以内质数个数约等于 x / ln(x)
ln是自然对数的意思。
准确的质数公式尚未给出。
10 以内共 4 个质数。
100 以内共 25 个质数。
1000 以内共 168 个质数。
10000 以内共 1228 个质数。
100000 以内共 9591 个质数。
1000000 以内共 78498 个质数。
10000000 以内共 664578 个质数。
100000000 以内共 5761455 个质数。
......
古老的筛法可快速求出100000000以内的所有素数。
筛法,是求不超过自然数N(N>1)的所有质数的一种方法。据说是古希腊的埃拉托斯特尼(Eratosthenes,约公元前274~194年)发明的,又称埃拉托斯特尼筛子。
具体做法是:先把N个自然数按次序排列起来。1不是质数,也不是合数,要划去。第二个数2是质数留下来,而把2后面所有能被2整除的数都划去。2后面第一个没划去的数是3,把3留下,再把3后面所有能被3整除的数都划去。3后面第一个没划去的数是5,把5留下,再把5后面所有能被5整除的数都划去。这样一直做下去,就会把不超过N的全部合数都筛掉,留下的就是不超过N的全部质数。因为希腊人是把数写在涂腊的板上,每要划去一个数,就在上面记以小点,寻求质数的工作完毕后,这许多小点就像一个筛子,所以就把埃拉托斯特尼的方法叫做“埃拉托斯特尼筛”,简称“筛法”。(另一种解释是当时的数写在纸草上,每要划去一个数,就把这个数挖去,寻求质数的工作完毕后,这许多小洞就像一个筛子。)
程序
#include<stdio.h>
#include<time.h>
#define MAX 100000010
int n,p[MAX],tot=0;
double s,t;
FILE *fp;
void prime()
{ int i,j,t=sqrt(n)+1;
for(i=2;i<t;i++)
if(p[i])
{ fprintf(fp,"%d\n",i);
tot++;
j=i+i;
while(j<n)
{ p[j]=0;
j+=i;
}
}
for(i=t+1;i<n;i++)
if(p[i])
{ tot++;
fprintf(fp,"%d\n",i);
}
}
main()
{ int i;
fp=fopen("prime.txt","w");
scanf("%d",&n);
s=clock();
for(i=0;i<n;i++)
p[i]=1;
prime();
t=clock();
fprintf(fp,"Num = %d\nTime = %.0lf ms\n",tot,t-s);
fclose(fp);
}
本机测试结果:10000000用时1156ms(1.156秒)
100000000用时80秒(较慢,主要是内存太少,反复读硬盘的原因)
1 朴素筛法,就是直接试除
2 若a是n的因子,那么n/a也是n的因子,所以如果n有一个大于1的真因子,则必有一个不大于n的1/2次方的因子
3 进一步的,如n是合数,他必有一个素因子不大于n的1/2次方,如要检测一个m以内的数是否为素数需事先建立一个m的1/2次方以内素数表。
4 Miller-Rabbin算法
5 概率算法
6 无条件的素数测试(包含APR算法 Jacobi sum测试 等)
7.n的n次幂除以n,若余数为2,则n为质数
......
效率比较:
效率比较一般的有 Eraosthenes氏筛选法
效率较高的有
Jacobbi Sums测试
更好的有
Miller-Rabbin算法(Monte-Carlo系列的算法)
不过这个是概率算法,依赖于 ERH(extend Riemann Hypothesis)
现在使用的素数判定算法还有
Unconditional Primality Test(基于Algebraic Number Theory)
近15年来还有椭圆曲线算法,
APR, Random Curve, Abelian Variety测试
根据素数定理,素数平均分布稠密程度π(x)/x≈1/lnx,对于512位大整数,随机产生为素数概率约为1/355,继而我们对每个随机数利用Miller-Rabbin测试,不断选取基b,计算是否每次都有bn-1 mod n=1都成立,则n几乎肯定是素数。由于多次运行后出错概率非常小,在实际中是可以信赖的。在Java里,BigInteger类提供的isProbablePrime()函数帮助简化了测试操作。
代码仅供参考,属于概率型,不保证求出的都是质数。
bool miller-rabin(unsigned char *n,int len)
{
unsigned char *a,*b,*c;
int la,lb,i,lc;
a=GetRInt(2);
la=2;
lb=len;
b=new unsigned char[len];
c=new unsigned char[2];
lc=1;
c[0]=1;c[1]=0;
for(i=0;i<lb;i++)
b[i]=n[i];
i=0;
while(1)
{
if(b[i]==0)
{
b[i]=255;
i++;
}else
{
b[i]--;
break;
}
}
while(lb!=0)
{
if(b[0]%2!=0)
{
c=Mul(a,c,la,&lc);
mod(c,n,&lc,len);
}
div2(b,&lb);
a=Square(a,&la);
mod(a,n,&la,len);
}
if(lc==1&&c[0]==1)return true;
return false;
素数是这样的整数,它除了能表示为它自己和1的乘积以外,不能表示为任何其它两个整数的乘积。例如,15=3×5,所以15不是素数;又如,12=6×2=4×3,所以12也不是素数。另一方面,13除了等于13×1以外,不能表示为其它任何两个整数的乘积,所以13是一个素数。
有的数,如果单凭印象去捉摸,是无法确定它到底是不是素数的。有些数则可以马上说出它不是素数。一个数,不管它有多大,只要它的个位数是2、4、5、6、8或0,就不可能是素数。此外,一个数的各位数字之和要是可以被3整除的话,它也不可能是素数。但如果它的个位数是1、3、7或9,而且它的各位数字之和不能被3整除,那么,它就可能是素数(但也可能不是素数)。没有任何现成的公式可以告诉你一个数到底是不是素数。你只能试试看能不能将这个数表示为两个比它小的数的乘积。
找素数的一种方法是从2开始用“是则留下,不是则去掉”的方法把所有的数列出来(一直列到你不想再往下列为止,比方说,一直列到10,000)。
第一个数是2,它是一个素数,所以应当把它留下来,然后继续往下数,每隔一个数删去一个数,这样就能把所有能被2整除、因而不是素数的数都去掉。在留
下的最小的数当中,排在2后面的是3,这是第二个素数,因此应该把它留下,然后从它开始往后数,每隔两个数删去一个,这样就能把所有能被3整除的数全
都去掉。下一个未去掉的数是5,然后往后每隔4个数删去一个,以除去所有能被5整除的数。再下一个数是7,往后每隔6个数删去一个;再下一个数是11
,往后每隔10个数删一个;再下一个是13,往后每隔12个数删一个。……就这样依法做下去。
你也许会认为,照这样删下去,随着删去的数越来越多,最后将会出现这样的情况;某一个数后面的数会统统被删去崮此在某一个最大的素数后面,再也不
会有素数了。但是实际上,这样的情况是不会出现的。不管你取的数是多大,百万也好,万万也好,总还会有没有被删去的、比它大的素数。
事实上,早在公元前300年,希腊数学家欧几里得就已证明过,不论你取的数是多大,肯定还会有比它大的素数,假设你取出前6个素数,并把它们乘在
一起:2×3×5×7×11×13=30030,然后再加上1,得30031。这个数不能被2、3、5、7、11、13整除,因为除的结果,每次都会余1。如果30031除了自己以外不能被任何数整除,它就是素数。如果能被其它数整除,那么30031所分解成的几个数,一定都大于13。事实上,3
0031=59×509。
对于前一百个、前一亿个或前任意多个素数,都可以这样做。如果算出了它们的乘积后再加上1,那么,所得的数或者是一个素数,或者是比所列出的素数还要大的几个素数的乘积。不论所取的数有多大,总有比它大的素数,因此,素数的数目是无限的。
随着数的增大,我们会一次又一次地遇到两个都是素数的相邻奇数对,如5,7;11,13;17,19;29,31;41,43;等等。就数学家所能及的数来说,它们总是能找到这样的素数对。这样的素数对到底是不是有无限
个呢?谁也不知道。数学家认为是无限的,但他们从来没能证明它。这就是数学家为什么对素数感兴趣的原因。素数为数学家提供了一些看起来很容易、但事实
却非常难以解决的问题,他们目前还没能对付这个挑战哩。
来源 :百度
id: 296560669
title: 关于素数(Java求素数<副>)
publishTime: 1217500292607
classId: 88735827
moveForm: NONE
没有评论 :
发表评论