【劍指Offer】66.構建乘積數組(java)

LeetCode/劍指Offer/構建乘積數組

劍指Offer其他題目代碼

給定一個數組 A[0,1,…,n-1],請構建一個數組 B[0,1,…,n-1],其中 B 中的元素 B[i]=A[0]×A[1]×…×A[i-1]×A[i+1]×…×A[n-1]。

不能使用除法。

【思路】

這道題目的難點就在於不能使用除法,否則一個for就可以搞定了。

你有張良計,我有過牆梯。

一個for不行,那就多來幾個,當然,不是嵌套在一起,不然就要超時了。

先來看一下B[i]的定義:

B[i] = \prod_{u=0}^{i-1}A[u] *\prod_{u=i+1}^{n}A[u]

很容易看出,i將A數組劈成了兩半,那麼,可以考慮用i這個位置去存儲i位置之前元素的乘積,或者之後元素的乘積。

定義兩個和A等長的數組,來搞定這件事。圖解(因爲比較大,就放在了資源裏)

int[] b = new int[len];//存儲i位置之前所有元素的乘積
b[0] = 1;
for (int i = 1; i < len; i++) {
    b[i] = b[i - 1] * a[i - 1];
}
        
int[] c = new int[len];//存儲i位置之後所有元素的乘積
c[len - 1] = 1;        
for (int i = len - 2; i >= 0; i--) {
    c[i] = c[i + 1] * a[i + 1];
}

然後,將兩個數組對應位置的元素相乘,便可得到答案。

用到了3個臨時數組,跑了3個for循環,時空複雜度均爲O(n).

【代碼】

class Solution {
    public int[] constructArr(int[] a) {
        if (a.length == 0)
            return new int[0];
        int len = a.length;
        int[] b = new int[len];
        int[] c = new int[len];
        int[] res = new int[len];
        b[0] = 1;
        for (int i = 1; i < len; i++) {
            b[i] = b[i - 1] * a[i - 1];
        }
        c[len - 1] = 1;
        for (int i = len - 2; i >= 0; i--) {
            c[i] = c[i + 1] * a[i + 1];
        }

        for (int i = 0; i < len; i++) {
            res[i] = b[i] * c[i];
        }
        return res;
    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章