例题
描述
给定一个数组 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](除 A[i] 以外的全部元素的的乘积)。程序中不能使用除法。(注意:规定 B[0] = A[1] * A[2] * … * A[n-1],B[n-1] = A[0] * A[1] * … * A[n-2])
对于 A 长度为 1 的情况,B 无意义,故而无法构建,用例中不包括这种情况。
数据范围:1 \le n \le 10 \1≤n≤10 ,数组中元素满足 |val| \le 10 \∣val∣≤10
示例1
输入:
[1,2,3,4,5]
返回值:
[120,60,40,30,24]
示例2
输入:
[100,50]
返回值:
[50,100]
解决方案
def multiply(A):
count = 0
B = []
flag = True
while count < len(A):
result = 1
C = A.copy()
C.pop(count)
for i in C:
result *= i
B.append(result)
count += 1
return B
总结
时间复杂度有点高,回头得优化下