谁可以帮我看下算法吗

图片说明
求一个最接近0.618的数,i/j,i,j取值范围都在1到20,i,j不能同时为偶数
谢谢大佬指导!!!!!!!!!!!!!!!!!

调试了一下你的代码,主要是第14、21行的不同

public static void main(String[] args) {
        double a,a1=0,c=0,d=0,e,f;
        double b=0.618;
        for (int i=1;i<=20;i++){
            for(int j=1;j<=20;j++){

                if (i%2==0&&j%2==0)
                    continue;

                a=(double)i/(double)j;

                if(i!=1&&j!=1) {
                    if (a > b)
                        e = a - b;
                    else
                        e = b - a;

                    if (a1 > b)
                        f = a1 - b;
                    else
                        f = b - a1;

                    if (e < f) {
                        c = i;
                        d = j;
                        a1=a;
                    }
                }
            }
        }
        System.out.println("hello,world!!"+c+"/"+d);
    }

这个问题其实挺好玩的,
斐波那契数列n与n+1个元素的除数,随着n的增大,无限接近于0.618,所以最后求出来的值应该在斐波那契数列里,我得到的是8与13

你到底要让什么数字最后接近0.618?看你最后结果也不是啊。莫名其妙的问题。