gpt4 book ai didi

java - 如何用这段代码使Java递归?

转载 作者:行者123 更新时间:2023-12-02 00:43:56 25 4
gpt4 key购买 nike

我有可以输出素数的代码,但该程序使用trycatch。你能帮我用递归来改变这个程序吗?

package file;

import javax.swing.JOptionPane;

public class Snake {

private static int getNilai(int number, int index) {
if (index == 1)
return 1;
else if (number % index == 0)
return 1 + getNilai(number, --index);
else
return 0 + getNilai(number, --index);
}

public static boolean cekPrime(int num) {
if (num > 1)
return (getNilai(num, num) == 2);
else
return false;
}

public static void main(String[] args) {
while (true) {
try {
int n = Integer.parseInt(JOptionPane
.showInputDialog("Enter your number!"));
if (n > 0) {
int a = 0;
int b = 0;
int p[] = new int[n * n];
while (b < (n * n)) {
if (cekPrime(a)) {
p[b] = a;
b++;
}
a++;
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
int m = ((i + 1) + (j * n)) - 1;
System.out.print(p[m] + "\t");
}
System.out.println();
}
break;
} else {
JOptionPane.showMessageDialog(null,
"Sorry, your input must be higher than 0!",
"System Error", JOptionPane.ERROR_MESSAGE);
}
} catch (NumberFormatException nfe) {
JOptionPane.showMessageDialog(null,
"You must entering number not word!", "System Error",
JOptionPane.ERROR_MESSAGE);
}
}
}
}

最佳答案

由于这一行,代码使用了 try-catch

int n = Integer.parseInt(JOptionPane.showInputDialog("Enter your number!"));

不是因为“非递归性”。要使程序递归,请将逻辑放入方法中,而不是执行循环,而是再次调用方法本身。仅当条件为真(不为真)时才会执行调用。在这种情况下,不要再次调用该方法,而是返回计算值(或其他值)

除此之外,还有更简单的代码来检查数字是否为素数......

关于java - 如何用这段代码使Java递归?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5521658/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com