构建乘积数组

构建乘积数组

http://www.nowcoder.com/questionTerminal/94a4d381a68b47b7a8bed86f2975db46

可以使用这张图来辅助理解,蓝色的部分在第一次循环中,红色的部分在第二次循环中。

import java.util.ArrayList;
public class Solution {
    public int[] multiply(int[] A) {
        int[] b=new int[A.length];
        int multi = 1;
        b[0] = 1;
        for(int i=1;i<A.length;i++){
            multi *= A[i-1];
            b[i] = multi;
        }
        
        multi = 1;
        for(int i=A.length-2;i>=0;i--){
            multi *= A[i+1];
            b[i] *= multi;
        }
        
        return b;
    }
}


全部评论

相关推荐

评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务