哥德巴赫猜想验证案例


点击(此处)折叠或打开

  1. package test;
  2. /**验证3-100中的所有偶数都能表示为两个质数之和*///质数是 除了1和它本身外,不能被其他自然数整除
  3. public class Guess2 {
  4.     //如果满足猜想就输出\"猜想是正确的\" 不满足就输出\"猜想不正确\"
  5.     public static void main(String[] args) {
  6.         System.out.println(\"在1~100范围内,现在开始证实哥德巴赫猜想:\");
  7.         if (testifyGuess(1, 100)) {             
  8.             System.out.println(\"在 1~100范围内,哥德巴赫猜想是正确的。\");
  9.         } else {
  10.             System.out.println(\"哥德巴赫猜想是错误的\");
  11.         }
  12.     }


  13.     /**
  14.      A.验证哥德巴赫猜想:从最小数low到最大数high拿到每一个数传入到isGoldbach()中进行验证
  15.             当有一个数不满足就返回false,所有数都满足就返回true*/
  16.     public static boolean testifyGuess(int low, int high) {
  17.         int i, j = 0;
  18.         boolean flag = true;
  19.         for (i = low; i <= high; i++){
  20.             if (i%2 == 0 && i>2){
  21.                 if (isGoldbach(i)){
  22.                     j++;
  23.                     if (j == 5) {
  24.                         System.out.println();
  25.                         j = 0;
  26.                     }
  27.                 } else {
  28.                     flag = false;
  29.                     break;
  30.                 }
  31.             }
  32.         }
  33.         return flag;
  34.     }

  35.     /**B.真正进行验证哥德巴赫猜想的方法(testifyGuess方法是调用这个方法进行验证的 )
  36.      * 验证整数a是否满足猜想:从1到a/2之间拿到每一个数i, 看i和a-i这一对数是否都是质数
  37.      * 如果是就结束循环返回true,如果在1到a/2之间没有一对数符合就返回false
  38.      */
  39.     public static boolean isGoldbach(int a) {
  40.         int i;boolean flag = false;
  41.         for (i = 1; i <= a / 2; i++) {
  42.             if (isPrime(i) && isPrime(a - i)) {
  43.                 flag = true;
  44.                 System.out.print(a + \"=\" + i + \"+\" + (a - i) + \" \");
  45.                 break;
  46.             }
  47.         }
  48.         return flag;
  49.     }

  50.     
  51.     
  52.     /**C.验证一个数是否是质数: 除了1和它本身外,不能被其他自然数整除
  53.             如果这个数i是1就返回false表示这个数不是质数
  54.            如果这个数i不是1,就从2到i-1之间拿到每一个数n,判断这个数是否能被n整除
  55.            如果能整除就返回false表示此数i不是质数,
  56.            如果2到i-1之间所有数都不能整除i就返回true表示此数是质数
  57.      */
  58.     public static boolean isPrime(int i) {
  59.             int n; boolean flag = true;
  60.             if (1 == i){flag = false;}
  61.             for (n = 2; n <= i - 1; n++)
  62.                 if (i % n == 0) {
  63.                     flag = false;
  64.                     break;
  65.             }
  66.             return flag;
  67.     }
  68. }
  69. //看本题应该从下往上看,先看懂isPrime()然后,再看isGoldbach最,后看testifyGuess


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/30246495/viewspace-1669429/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/30246495/viewspace-1669429/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值