构建乘积数组 python

2018-08-29  本文已影响0人  小歪与大白兔

题目描述
给定一个数组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循环,进行连乘,中间判断一下i != j 即可。时间复杂度O(n^2)

# -*- coding:utf-8 -*-
class Solution:
    def multiply(self, A):
        # # write code here
        #思路一:时间复杂度O(n^2)
        n = len(A)
        B = [1 for i in range(n)]
        for i in range(n):
            for j in range(n):
                if i != j:
                    B[i] *= A[j]
        return B

思路二:三角形问题,时间复杂度O(n)
[图片上传失败...(image-7281f5-1535524536475)]

第一步:计算下三角,也就是每行的【】之前的乘积

第一步:b[0] = 1;
第二步:b[1] = b[0] * a[0] = a[0]
第三步:b[2] = b[1] * a[1] = a[0] * a[1];
第四步:b[3] = b[2] * a[2] = a[0] * a[1] * a[2];
第五步:b[4] = b[3] * a[3] = a[0] * a[1] * a[2] * a[3];

第二步:计算上三角,也就是每行【】之后的乘积

第一步
temp *= a[4] = a[4];
b[3] = b[3] * temp = a[0] * a[1] * a[2] * a[4];
第二步
temp *= a[3] = a[4] * a[3];
b[2] = b[2] * temp = a[0] * a[1] * a[4] * a[3];
第三步
temp *= a[2] = a[4] * a[3] * a[2];
b[1] = b[1] * temp = a[0] * a[4] * a[3] * a[2];
第四步
temp *= a[1] = a[4] * a[3] * a[2] * a[1];
b[0] = b[0] * temp = a[4] * a[3] * a[2] * a[1];

# -*- coding:utf-8 -*-
class Solution:
    def multiply(self, A):
        # # write code here
        #思路二:时间复杂度O(n)
        n = len(A)
        B = [1 for i in range(n)]
        for i in range(1,n):
            B[i] = B[i-1] * A[i-1]
        tmp = 1
        for i in range(n-2,-1,-1):
            tmp *= A[i+1]
            B[i] *= tmp
        return B

上一篇 下一篇

猜你喜欢

热点阅读