亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

將數字數組傳遞給遞歸 Java 程序

將數字數組傳遞給遞歸 Java 程序

繁花不似錦 2022-06-23 17:33:38
我正在編寫一個顯示 m(i) 的程序,i = 1,2,3,4,5,107,1060。結果應該是雙精度值。而系列是 m(i) = 1/2 + 2/3 +.....i/i+1我正在嘗試使用數組傳遞所需的數字。但是我遇到了兼容性問題。到目前為止,我有這個:public class Recursive {    public static void main(String[] args){        int[] s;        s = new int[]{1,2,3,4,5,107,1060};        System.out.println(""   ,m(s));    }    public static double m(int i){        double result;        if(i > 1){            result = i/(i + 1) + m(i - 1);        } else{            result = i/(i + 1);        }        return result;    }}
查看完整描述

3 回答

?
米琪卡哇伊

TA貢獻1998條經驗 獲得超6個贊

根據您收到的評論,大多數人認為您的問題是:


public class Recursive {


    public static double m(int i) {

        double result = i / (i + 1.0);


        if (i > 1) {

            result += m(i - 1);

        }


        return result;

    }


    public static void main(String[] args) {

        int[] s = {1, 2, 3, 4, 5, 107, 1060};


        for (int i : s) { 

            System.out.println("m(" + i + ") = " + m(i));

        }

    }

}

因為順序應該是 1/2 + 2/3 + 3/4 + 4/5+ 5/6 + 107/108+ 1060/1061


這闡明了您確實在要求:


public class Recursive {


    public static double m(int i, int[] s) {

        double result = s[i] / (s[i] + 1.0);


        if (i > 0) {

            result += m(i - 1, s);

        }


        return result;

    }


    public static void main(String[] args) {

        int[] s = {1, 2, 3, 4, 5, 107, 1060};


        System.out.println(m(s.length - 1, s));

    }

}

哪個有效,除非s是一個空數組——就像你的問題的其他潛在答案一樣。


查看完整回答
反對 回復 2022-06-23
?
慕妹3146593

TA貢獻1820條經驗 獲得超9個贊

首先,您需要將數組作為參數傳遞給方法m(),

或者您可以在類級別聲明數組以避免遞歸開銷。

對于這個小數組,讓我們采用第一種方法。

然后,m()你在內心犯了一個必須糾正的邏輯錯誤。

你需要 sums[i]/s[i] + 1而不是i / (i + 1)。

還有if語句 from i > 1to中的條件,i > 0因為數組的索引是0基于的:


public static void main(String[] args){

    int[] s = new int[]{1, 2, 3, 4, 5, 107, 1060};

    System.out.println(m(s, 6));

}


public static double m(int[] s, int i){

    double result;

    if(i > 0){

        result = 1.0 * s[i]/(s[i] + 1) + m(s, i - 1);

    } else{

        result = 1.0 * s[i]/(s[i] + 1);

    }

    return result;

}

需要相乘的因子1.0來避免整數除法:


s[i]/(s[i] + 1) 

這總是會導致0


查看完整回答
反對 回復 2022-06-23
?
手掌心

TA貢獻1942條經驗 獲得超3個贊

該方法m()需要一個參數,int但您正在傳遞整個數組。保留一個 for 循環并傳遞m()for 每個元素或處理m()



查看完整回答
反對 回復 2022-06-23
  • 3 回答
  • 0 關注
  • 124 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號