武汉科技大学ACM :1009: 华科版C语言程序设计教程(第二版)例题4.18

Problem Description

 验证哥德巴赫猜想:任何充分大(>=4)的偶数都可以用两个素数之和表示。

Input

 输入一个偶数n。(2<n<=10000)

Output

 找到a、b使得 n=a+b

其中a、b为两个素数,且a<=b。

Sample Input

4

100

Sample Output

2 2

3 97

 1 #include <iostream>
 2 
 3 #include<math.h>
 4 
 5 using namespace std;
 6 
 7 int prime(int m)
 8 
 9 {
10 
11          int i,n;
12 
13          if(m==1)return 0;
14 
15          n=(int)sqrt((double)m);
16 
17          for(i=2;i<=n;i++)
18 
19                    if(m%i==0)return 0;
20 
21                    return 1;
22 
23 }
24 
25 int main()
26 
27 {
28 
29          int count,i,number;
30 
31          count=0;
32 
33          while(cin>>number)
34 
35          {
36 
37                    for(i=2;i<=number/2;i=i+1)
38 
39                             if(prime(i)&&prime(number-i))
40 
41                             {
42 
43                                      cout<<i<<" "<<number-i<<endl;
44 
45                                      break;
46 
47                             }
48 
49          }
50 
51          return 1;
52 
53 }

其他代码:

 1 #include<stdio.h>
 2 #include<math.h>
 3 int prime (int m)
 4 {
 5     int r = m/2;
 6     for (int i = 2; i <= r; i++)
 7         if (m % i == 0)
 8             return 0;
 9     return 1;
10 }
11 int main()
12 {
13     int n,i;
14     while(~scanf("%d",&n))
15     {
16         for(i=2;i<=n/2;i++)
17             if(prime(i)&&prime(n-i)){
18                 printf("%d %d\n",i,n-i);
19                 break;
20             }
21     }
22     return 0;
23 }

 

posted @ 2014-12-09 21:15  liuwt365  阅读(436)  评论(0编辑  收藏  举报