
本文旨在解决 Java 程序中遇到的无限输入问题,并以一个计算特定级数和的示例代码为例,详细分析了问题产生的原因以及如何通过代码调试和改进来避免无限循环,从而实现程序的正常运行并提供更友好的用户体验。
原始代码在计算级数 (x ^ 2)/(1!) + (x ^ 4)/(3!) + (x ^ 6)/(5!) + ... + (x ^ n)/((n - 1)!) 的和时,出现了无限循环的问题。经过分析,问题出在内部循环的条件控制上:
for (k = 1; k <= j; j++) {
s = s * k;
}在这个循环中,循环变量 k 初始化为 1,循环条件是 k <= j,但循环体内的 j++ 导致 j 的值不断增大,使得循环条件始终成立,从而造成了无限循环。
要解决这个问题,需要将循环体内的 j++ 修改为 k++,确保循环变量 k 能够递增,最终使得循环条件不成立,从而跳出循环。修改后的代码如下:
立即学习“Java免费学习笔记(深入)”;
for (k = 1; k <= j; k++) {
s = s * k;
}此外,为了提高代码的可读性和健壮性,可以进行以下改进:
以下是改进后的完整代码:
import java.util.*;
public class SeriesSum {
private Scanner sc;
private boolean ok = true;
void accept() {
sc = new Scanner(System.in);
System.out.print("Enter the value of x and n, separated by a comma: ");
try {
String[] split = sc.nextLine().split(",");
int x = Integer.valueOf(split[0].trim());
int n = Integer.valueOf(split[1].trim());
compute(x, n);
} catch (NumberFormatException e) {
System.out.println("Bad input. Quitting.");
ok = false;
}
}
void compute(int x, int n) {
int i, j, k;
double f = 0.0;
for (i = 2; i <= n; i = i + 2) {
long s = 1; // Use long to prevent integer overflow for larger factorials
for (j = 1; j <= i - 1; j++) { // Corrected the inner loop to iterate up to i-1
s *= j;
}
f = f + ((Math.pow(x, i)) / s);
}
System.out.println("Sum of series: " + f);
}
void close() {
if (sc != null) {
sc.close();
}
}
public static void main(String[] args) {
SeriesSum input = new SeriesSum();
System.out.println("Hit Ctrl-break to quit.");
do {
input.accept();
} while (input.ok);
input.close();
}
}代码解释:
通过对原始代码的分析和改进,我们解决了无限输入的问题,并提高了代码的健壮性和可读性。在编写 Java 程序时,需要注意以下几点:
通过遵循这些建议,可以避免常见的编程错误,编写出高质量的 Java 程序。
以上就是Java 解决无限输入问题:一个级数求和的案例的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号