搜索
首页Javajava教程在Java中如何检查一个数是否为哥德巴赫数?

在Java中如何检查一个数是否为哥德巴赫数?

Aug 26, 2023 pm 05:25 PM
java检查哥德巴赫数

在Java中如何检查一个数是否为哥德巴赫数?

如果一个数可以表示为两个奇素数对的加法,则该数被称为哥德巴赫数

如果我们遵循上述条件,那么我们可以发现,每个大于4的偶数都是哥德巴赫数,因为它必须有任意一对奇素数对。但奇数并不令人满意,因为我们知道两个数相加永远不可能是奇数。

在本文中,我们将了解如何使用 Java 编程语言检查一个数是否为哥德巴赫数。

向您展示一些实例

实例1

输入数字为50。

让我们用哥德巴赫数的逻辑来检验一下。

求奇素数对,我们得到:

(3 , 47)
(7 , 43)
(13 , 37)
(19 , 31)

正如我们在这里注意到的,我们得到了一些奇素数对,它们的加法值等于 50。

因此,50 是一个哥德巴赫数。

实例2

输入数字为47。

让我们用哥德巴赫数的逻辑来检验一下。

找到奇数素数对,我们得到− 没有可用的素数对

正如我们在这里注意到的,我们没有得到任何加法值等于 47 的奇素数对。

因此,47 不是哥德巴赫数。

哥德巴赫数的其他一些示例包括 20、52、48、122 等。

算法

  • 第 1 步 - 通过初始化或用户输入获取整数。

  • 步骤 2 - 然后声明两个连续存储素数的数组。

  • 步骤 3 - 然后开始迭代,迭代中将从两个数组中找到两个奇素数对,其加法与输入数相同。

  • 步骤 4 - 如果我们得不到任何奇素数对,那么我们可以打印出给定的数字不是哥德巴赫数。

  • 第 5 步 - 如果我们得到一些对,那么我们只需打印这些对以及输入数字是哥德巴赫数的结果消息。

多种方法

我们通过不同的方式提供了解决方案。

  • 通过使用静态输入值

  • 通过使用用户定义的方法

让我们一一看看该程序及其输出。

方法 1:使用静态输入值

在这种方法中,将在程序中初始化一个整数值,然后通过使用算法我们可以检查一个数字是否是哥德巴赫数字。

示例

import java.io.*;
import java.util.*;
public class Main {
   public static void main(String args[]) {
      //declare all the variables
      int i, j, n, temp, b=0, c=0, sum=0;

      //declare a variable which stores the input number
      //assign a value to it
      int inputNumber=30;

      //declare a temporary variable which stores the input value
      temp=inputNumber;

      //declare two arrays with the capacity equal to input number
      int array1[]=new int[inputNumber];
      int array2[]=new int[inputNumber];

      //check whether the number is even or
      if(inputNumber%2!=0) {
         //if the input is not even then print it is not a Goldbach number
         System.out.println(inputNumber + " is not a Goldbach number.");
      }

      //if the input is even then proceed with further calculations
      else {

         //initiate the loop for finding the prime numbers
         for(i=1; i<=inputNumber; i++) {
            for(j=1; j<=i; j++) {
               if(i%j==0) {
                  c++;
               }
            }

            //find the odd prime numbers
            if((c==2)&&(i%2!=0)) {

               //stores odd prime numbers into first array
               array1[b]=i;

               //stores odd prime numbers into second array
               array2[b]=i;

               //increments the value of b by 1
               b++;
            }
            c=0;
         }
         //print the odd prime number pairs
         System.out.println("Odd Prime Pairs are: ");

         //loop for printing the value of ArrayStoreException
         for(i=0; i<b; i++) {
            for(j=i; j<b; j++) {

               //find the sum of two odd prime numbers
               sum=array1[i]+array2[j];

               //condition for comparing the sum value with input number
               if(sum==temp) {

                  //print pair of odd prime numbers
                  System.out.print("(" + array1[i]+" , "+array2[j] + ")");
                  System.out.println();
               }
            }
         }
         //print the final result if it is Goldbach number
         System.out.println(temp+" is a Goldbach number.");
      }
   }
}

输出

Odd Prime Pairs are:
(7 , 23)
(11 , 19)
(13 , 17)
30 is a Goldbach number.

方法2:使用用户定义的方法

在此方法中,初始化一个整数值,然后我们通过将此输入数字作为参数传递来调用用户定义的方法。

在该方法中,我们将使用算法检查一个数字是否是哥德巴赫数字。

示例

import java.io.*;
import java.util.*;
public class Main {
   public static void main(String args[]) {
      //declare a variable which stores the input number
      //assign a value to it
      int inp=98;
      if(checkGoldbach(inp)) {

         //if true it is Goldbach number
         System.out.println(inp+" is a Goldbach number.");
      } else {
         //if false it is not a Goldbach number
         System.out.println(inp + " is not a Goldbach number.");
      }
   }
   //define the user defined method
   static boolean checkGoldbach(int inputNumber) {

      //declare all the variables
      int i, j, n, temp, b=0, c=0, sum=0;

      //declare a temporary variable which stores the input value
      temp=inputNumber;

      //declare two arrays with the capacity equal to input number
      int array1[]=new int[inputNumber];
      int array2[]=new int[inputNumber];

      //check whether the number is even or
      if(inputNumber%2!=0) {
         return false;
      }

      //if the input is even then proceed with further calculations
      else {

         //initiate the loop for finding the prime numbers
         for(i=1; i<=inputNumber; i++) {
            for(j=1; j<=i; j++) {
               if(i%j==0) {
                  c++;
               }
            }

            //find the odd prime numbers
            if((c==2)&&(i%2!=0)) {

               //stores odd prime numbers into first array
               array1[b]=i;

               //stores odd prime numbers into second array
               array2[b]=i;

               //increments the value of b by 1
               b++;
            }
            c=0;
         }
         //print the odd prime number pairs
         System.out.println("Odd Prime Pairs are: ");

         //loop for printing the value of Arrays
         for(i=0; i<b; i++) {
            for(j=i; j<b; j++) {

               //find the sum of two odd prime numbers
               sum=array1[i]+array2[j];

               //condition for comparing the sum value with input number
               if(sum==temp) {

                  //print pair of odd prime numbers
                  System.out.print("(" + array1[i]+" , "+array2[j] + ")");
                  System.out.println();
               }
            }
         }
         return true;
      }
   }
}

输出

Odd Prime Pairs are:
(19 , 79)
(31 , 67)
(37 , 61)
98 is a Goldbach number.

在本文中,我们探讨了如何使用三种不同的方法在 Java 中检查一个数字是否为哥德巴赫数。

以上是在Java中如何检查一个数是否为哥德巴赫数?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:tutorialspoint。如有侵权,请联系admin@php.cn删除

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

Dreamweaver Mac版

Dreamweaver Mac版

视觉化网页开发工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

安全考试浏览器

安全考试浏览器

Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。