#CS51001. 完善程序10-数论-1哥德巴赫猜想
完善程序10-数论-1哥德巴赫猜想
哥德巴赫猜想
哥德巴赫猜想是指,任一大于 2 的偶数都可写成两个质数之和。迄今为止,这仍然是一个著名的世界难题,被誉为数学王冠上的明珠。试编写程序,验证任一大于 2 且不超过 n 的偶数都能写成两个质数之和。
#include <iostream>
using namespace std;
int main()
{
const int SIZE = 1000;
int n, r, p[SIZE], i, j, k, ans;
bool tmp;
cin>>n;
r = 1;
p[1] = 2;
for (i = 3; i <= n; i++) {
[ ① ];
for (j = 1; j <= r; j++)
if (i % [ ② ] == 0) {
tmp = false;
break;
}
if (tmp) {
r++;
[ ③ ] ;
}
}
ans = 0;
for (i = 2; i <= n / 2; i++) {
tmp = false;
for (j = 1; j <= r; j++)
for (k = j; k <= r; k++)
if (i + i == [ ④ ] ) {
tmp = true;
break;
}
if (tmp)
ans++;
}
cout<<ans<<endl;
return 0;
}
- ①处应填( ){{ select(1) }}
- k=0
- p[i]=i
- tmp=true
- p[i]=r
- ②处应填( ){{ select(2) }}
- p[j]
- p[n]
- n
- j
- ③处应填( ){{ select(3) }}
- p[r]=i
- p[j]=i
- tmp=true
- ans++
- ④处应填( ){{ select(4) }}
- j+k
- p[j]+p[k]
- p[j]
- p[k]
- ⑤处应填( ){{ select(5) }}
- 2010
- 1005
- 2009
- 1004