首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Naive的算法变体

Naive的算法变体
EN

Stack Overflow用户
提问于 2013-12-03 11:32:22
回答 1查看 125关注 0票数 0

伙计们,我正在做多项式计算,并使用Naive,Horner和FFT等算法,现在我的问题中有一句话说。

代码语言:javascript
复制
Run a variation of the naïve algorithm, where the exponentiation
is performed by repeated squaring, a decrease-by-half algorithm

我不明白,我目前的朴素算法是:

代码语言:javascript
复制
public Complex naive(Polynomial poly, Complex x) {
    Complex p = new Complex();
    for (int i = poly.getCoef().length - 1; i >= 0; i--) {
        Complex power = new Complex(1, 0);
        for (int j = 1; j <= i; j++) {
            power = power.multiply(x);

        }
        p = p.add(poly.getCoef()[i].multiply(power));
        multiplyCountNaive++;
    }
    return p;

}

请解释需要修改的内容。谢谢

EN

回答 1

Stack Overflow用户

发布于 2013-12-03 19:38:28

我明白了,应该是这样的。

代码语言:javascript
复制
public Complex naive2(Polynomial poly, Complex x) {
    Complex p = new Complex();
    for (int i = poly.getCoef().length - 1; i >= 0; i--) {
        p = p.add(poly.getCoef()[i].multiply(expo(x, i)));
        multiplyCountNaive2++;
    }
    return p;

}

private Complex expo(Complex a, int b) {
    if (b == 0) {
        return new Complex(1, 0);
    } else if (b == 1) {
        return a;
    }

    if (b % 2 == 0) {
        return expo(a.multiply(a), b / 2);
    } else {
        return a.multiply(expo(a.multiply(a), (b - 1) / 2));
    }

}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20342364

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档