一、题目
编写一个方法判断一个数是否为素数,且返回布尔值,利用该方法验证哥德巴赫猜想:任意一个不小于3的偶数都可以拆成两个素数之和,需要在键盘上输入限定查询范围。

二、实验代码

package fighting;
import java.util.Scanner;
public class fighting
{public static boolean isPrimeNumber(int n){if(n<2)//所有小于2的整数包括负整数、0和1既不是质数、也不是合数{return false;}for(int i=2;i<n;i++)//当判断2时,由于既不符合if(n<2)又不符合for(int i=2;i<n;i++)直接返回true,1是所有n>=2的所有整数的公因素,所以计数直接从2开始//质数的约数只有1和本身,不能被比它小的数整除{if(n%i==0){return false;}}return true;}public static void main(String[] args)        {System.out.println("请输入验证哥德巴赫猜想需要查询数的范围:");Scanner sc=new Scanner(System.in);int m=sc.nextInt();System.out.println("输出结果为:");for(int n=4;n<=m;n+=2)//哥德巴赫猜想前提是任意一个不小于3的偶数,所以计数从n=4开始,且以n+=2增加保证全是偶数{for(int i=2;i<n;i++){if(isPrimeNumber(i)&&isPrimeNumber(n-i)){System.out.println(n+"="+i+","+(n-i));}}}}
}

三、运行结果

四、实验总结
1、质数的定义:质数(Prime number),又称素数,是指在大于1的自然数中,除了1和该数自身外,无法被其他自然数整除的数。其中0和1既不是质数也不是合数,2为最小的质数,质数的约数只有1和其本身。
2、判断一个数是否为素数有以下两种常见的方法。一是根据质数的约数只有1和其本身,不能被比它小的数整除,其时间复杂度为O(n),代码如下:

public static boolean isPrimeNumber(int n){if(n<=3){return n>1;//返回的为只能为2和3,直接return true}for(int i=2;i<n;i++){if(n%i==0){return false;}}return true;}

二是根据当一个数不是质数时,必定存在两个约数,一个大于等于sqrt(n),另一个小于等于sqrt(n)。利用这种特性,数n不能被小于sqrt(n)的数整除,其时间复杂度为O(sqrt(n)),代码如下:

public static boolean isPrimeNumber(int n){if(n<=3){return n>1;//返回的为只能为2和3,直接return true}for(int i=2;i<=(int)Math.sqrt(n);i++)//Math.sqrt(n)求出的数为double类型需要进行强转成int类型{if(n%i==0){return false;}}return true;}

Java编程之验证哥德巴赫猜想相关推荐

  1. Java编程验证哥德巴赫猜想:任何一个大于6的偶数,都能分解成两个质数的和

    package com.pzhu.demo;import java.util.Scanner;public class Goldbach {//Java编程验证哥德巴赫猜想:任何一个大于6的偶数,都能 ...

  2. 实验4-2-3 pta验证“哥德巴赫猜想” (20分)

    验证"哥德巴赫猜想" (20分) 数学领域著名的"哥德巴赫猜想"的大致意思是:任何一个大于2的偶数总能表示为两个素数之和.比如:24=5+19,其中5和19都是 ...

  3. 验证哥德巴赫猜想:任何一个大于6的偶数均可表示为2个素数之和

    验证哥德巴赫猜想:任何一个大于6的偶数均可表示为2个素数之和。例如6=3+3,8=3+5,-,18=5+13。将6~100之间的偶数都表示成2个素数之和,打印时一行打印5组。素数就是只能被1和自身整除 ...

  4. 习题6-5 使用函数验证哥德巴赫猜想 (20 分)

    本题要求实现一个判断素数的简单函数,并利用该函数验证哥德巴赫猜想:任何一个不小于6的偶数均可表示为两个奇素数之和.素数就是只能被1和自身整除的正整数.注意:1不是素数,2是素数. 函数接口定义: in ...

  5. ZZULIOJ 1093: 验证哥德巴赫猜想(函数专题)

    验证哥德巴赫猜想(函数专题) 题目描述 哥德巴赫猜想大家都知道一点吧.我们现在不是想证明这个结论,而是对于任给的一个不小于6的偶数,来寻找和等于该偶数的所有素数对.做好了这件实事,就能说明这个猜想是成 ...

  6. 7-158 验证“哥德巴赫猜想” (20 分)

    7-158 验证"哥德巴赫猜想" (20 分) 数学领域著名的"哥德巴赫猜想"的大致意思是:任何一个大于2的偶数总能表示为两个素数之和.比如:24=5+19,其 ...

  7. 7-160 验证“哥德巴赫猜想” (20 分)

    7-160 验证"哥德巴赫猜想" (20 分) 数学领域著名的"哥德巴赫猜想"的大致意思是:任何一个大于2的偶数总能表示为两个素数之和.比如:24=5+19,其 ...

  8. (C语言)验证哥德巴赫猜想,输入一个大于6的偶数,输出这个数能被分解为哪两个质数的和

    (C语言)验证哥德巴赫猜想,输入一个大于6的偶数,输出这个数能被分解为哪两个质数的和,如10=3+7,12+5+7. // 质数:除了1和自身,不能被任何数整除的数 #include<stdio ...

  9. 【算法】验证哥德巴赫猜想

    问题来源 Timus Online Judge 网站上有这么一道题目:1356. Something Easier.这道题目的输入是一组  2 到 109 之间整数,对于每个输入的整数,要求用最少个数 ...

  10. 实验4-2-3 验证“哥德巴赫猜想” (20 分)

    实验4-2-3 验证"哥德巴赫猜想" (20 分) 数学领域著名的"哥德巴赫猜想"的大致意思是:任何一个大于2的偶数总能表示为两个素数之和.比如:24=5+19 ...

最新文章

  1. 2019年云计算发展状态
  2. 计算机试题dddd,数据库系统概论试题及答案dddd_Image_Marked.pdf
  3. P1156-垃圾陷阱【dp】
  4. Python函数中参数* 和 ** 的区别
  5. 华为上架自主地图应用Here WeGo 或登录HMS系统成为预装应用
  6. rust腐蚀深井_深井开采中的地压现象致因分析及措施_高光
  7. 利用MATLAB平台实现字的语音识别功能
  8. python--split方法
  9. [UE4]暂停游戏、退出游戏、游戏输入模式
  10. 【9933】单词的划分
  11. 管理员取得所有权限.reg
  12. php对接触动精灵,触动精灵万能连点器 Lua 源码
  13. 抖音快手短视频去水印API,接口开发文档
  14. 爬虫——Scrapy框架案例二:阳光问政平台
  15. Android系统安装Linux 系统的ubuntu版本
  16. Win7设置wifi热点
  17. 【PC工具】PC好用的迅雷下载版本合集,hash资源下载方法,石皮版迅雷软件去广告优化增强典藏版...
  18. 《MySQL DBA修炼之道》——3.3 SQL基础
  19. PLY的LALR语法详细解释
  20. 【一问一答】错题库整理

热门文章

  1. BroadLink:三款新品力求无障碍人机交互,三大平台分三期对外开放...
  2. Halcon例程学习(1)——Atoms
  3. SQL Server2005安装材料及教程编制
  4. 求用100文钱买100只鸡 公鸡 母鸡 小鸡的只数
  5. MATLAB学习_控制语句:for,while,if
  6. zookeeper 入门到精通
  7. OPPO手机进入相机花屏
  8. opencv自学《二》
  9. (Listing必备)亚马逊关联视频的重要性
  10. TYPE-C手机蓝牙领夹式麦克风方案,支持手机边充电边传输数据