2 回答

TA貢獻(xiàn)1770條經(jīng)驗(yàn) 獲得超3個贊
讓我們首先談?wù)劄槭裁茨憧吹侥闼吹降摹?/p>
我在這里重新發(fā)布了您的代碼,縮進(jìn)已更改以反映嵌套:
for(int i = 0; i < array1.length; i++) {
for(int j = 0; j < array2.length; j++) { // <--- This loop
calculations = ((array1[i] + array2[j]) % 10);
}
calculationsArray.add(calculations);
}
讓我們來看看我在上面標(biāo)記的那個內(nèi)部循環(huán)。請注意,在循環(huán)的每次迭代中,您都設(shè)置calculations了一個新值。這會覆蓋之前計算的值,因此當(dāng)內(nèi)部循環(huán)完成運(yùn)行時, 的值calculations將等于該循環(huán)中計算的最后一個值。這就是你實(shí)際看到的原因,因?yàn)?/p>
當(dāng) 時i = 0,內(nèi)循環(huán)的最后一次計算為(array1[0] + array2[6]) % 10,即(5 + 9) % 10= 4,
當(dāng) 時i = 1,內(nèi)循環(huán)的最后一次計算為(array1[1] + array2[6]) % 10,即(10 + 9) % 10= 9,
當(dāng) 時i = 2,內(nèi)循環(huán)的最后一次計算為(array1[2] + array2[6]) % 10,即(2 + 9) % 10= 1。
嘿,看![4, 9, 1]你看到的就是你的。
下一個問題是如何解決這個問題。我認(rèn)為您在這里遇到的主要問題是雙重嵌套循環(huán)可能不是解決問題的方法。具體來說,這里的雙 for 循環(huán)將運(yùn)行array1.length×array2.length次,這遠(yuǎn)遠(yuǎn)超過您需要它運(yùn)行的次數(shù)。
所以第一個問題——循環(huán)應(yīng)該運(yùn)行多少次?好吧,您希望輸出數(shù)組的長度是兩個輸入數(shù)組中較長者的長度,即Math.max(array1.length, array2.length)倍數(shù)。你能做一個循環(huán)來計算那個數(shù)字嗎?
然后您需要處理這樣一個事實(shí),即您的循環(huán)可能需要多次循環(huán)遍歷每個輸入數(shù)組。在您給出的示例中,您將讀取array1多次的值,因?yàn)閍rray2更長,但是如果更長,您可能不得不讀取array2多次的值array1。
作為如何執(zhí)行此操作的提示,請查看當(dāng)索引變得太大時是否可以使用 mod 運(yùn)算符%環(huán)繞。
希望這可以幫助!

TA貢獻(xiàn)1155條經(jīng)驗(yàn) 獲得超0個贊
怎么樣(未優(yōu)化):
ArrayList<Integer> calculationsArray = new ArrayList<Integer>();
int calculations = 0;
int j = 0;
while (j < array2.size()) {
for (int i = 0; i < array1.size(); i++) {
calculations = ((array1.get(i) + array2.get(j)) % 10);
calculationsArray.add(calculations);
}
j++;
}
添加回答
舉報