java遞歸調用 return的問題


最近比較閑,寫了個遞歸調用獲取最大公約數,剛開始寫錯了,但一直不明白錯在哪,錯誤代碼如下:

public class Demo {
    public static void main(String[] args) {
        int gcd = gcd(5, 15);
        System.out.println(gcd);
    }

    private static int gcd(int a, int b) {
        if (b != 0) {
            int i = a % b;
            a = b;
            b = i;

            gcd(a, b);
        }
        return a;
    }
}

  剛開始一直想不明白為什么當b!=0的時候 不直接return a的值 而是往gcd方法里走,直到a等於傳入的值時才返回

后來就寫了2個方法來debug

找到原因后 修改代碼如下:

public class Demo {
    public static void main(String[] args) {
        int gcd = gcd(4, 10);
        System.out.println(gcd);
    }

    private static int gcd(int a, int b) {
        if (b != 0) {
            int i = a % b;
            a = b;
            b = i;

            return gcd(a, b);
        }
        return a;
    }

}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM