java - 如何在Java中实现这个功能?

标签 java math recursion

我构建了以下函数,用于在 Python 中查找数字的 n 次方根:

def find_root(base, nth_root, top = None, bottom = 0):
    if top == None: top = base

    half = (float(top) + float(bottom)) / 2.0 

    if half**nth_root == base or half == top or half == bottom:
        return half
    if half**nth_root > base:
        return find_root(base, nthRoot, half, bottom)
    if half**nth_root < base:
        return find_root(base, nthRoot, top, half)

您可能会说它高度依赖于默认参数。是否有 (1) 更好的方法(我希望它是递归的),以及 (2)(这个问题的答案可能与 1 相同)如果语言不支持默认参数,我如何在 Java 中执行此操作?

我是 Java 的新手,正在尝试找出差异。

谢谢,

迈克尔·G。

最佳答案

您可以使用 method overloading模拟默认参数:

int find_root(int base, int nth_root) {
  return find_root(base, nth_root, -1, 0);
}

int find_root(int base, nth_root, int top, int bottom) {
    // ...
}

关于java - 如何在Java中实现这个功能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11954005/

相关文章:

java - 通过Rest Template访问第三方服务器时双向身份验证如何工作

java - 如何在 ArrayList 中添加 10 个特定产品(对象),每个产品(对象)具有不同的数据类型?

java - 如何将 UTC 时间转换为设备的本地时间?

javascript - 圆形辐射辐条

xml - 遍历完整的 XML 文档

c++ - 有效但没有多大意义的返回语句

java - SharedPreferences 使程序崩溃

java - 用于操纵帆船的控制算法或函数

java - 乘法是否可以进行短路评估?

java - 响应时间随着 Java 中并发性的增加而增加