取一个整数范中大于另一个整的随机数 public int RandG(int a, int b) Random r = new Random(): int t = r.nextnt(b); if (t > a) return t: else RandG(a,b); return t; 问题 a. 该方法采用的什么算法: b. 请指出代码中存在的问题:
时间: 2024-02-24 15:57:54 浏览: 15
a. 该方法采用的是递归算法。当随机生成的数字小于等于 a 时,该方法会递归调用自身,直到生成的数字大于 a 为止。
b. 代码中存在以下问题:
1. 方法名应该使用小写字母开头,符合 Java 命名规范。
2. 方法应该添加访问修饰符,比如 `public`。
3. `Random.nextInt()` 方法的参数应该是整数,而代码中使用了 `b`。
4. 递归调用时应该使用 `return` 关键字返回结果,而代码中没有使用 `return`。
5. 当递归调用时,没有限制递归的深度,可能会导致栈溢出。
6. 如果参数 `a` 的值大于等于 `b` 的值,该方法会进入死循环,应该在方法开始时添加判断避免这种情况。
下面是修改后的代码:
```
public int randG(int a, int b) {
if (a >= b) {
throw new IllegalArgumentException("a must be smaller than b");
}
Random r = new Random();
int t = r.nextInt(b - a) + a;
if (t > a) {
return t;
} else {
return randG(a, b);
}
}
```
修改后的代码中,使用 `IllegalArgumentException` 抛出异常,避免了参数 `a` 大于等于 `b` 时进入死循环的情况,使用 `return` 关键字返回结果,避免了递归调用时返回结果错误的问题,使用 `nextInt(b - a) + a` 生成大于等于 `a`、小于 `b` 的随机数,避免了原代码中使用了错误的参数的问题。