【剑指offer】51 构建乘积数组

题目

在这里插入图片描述

分析

不能使用除法,那么就构建两个数组
数组1 larr,第一位是1,其余位的数是A0A1Ai-1
数组2 rarr,最后一位是1,其余位是Ai+1
Ai+2*…*An-1
最后返回B,B的每一位是larr[i]*rarr[i]

python代码

class Solution:
    def multiply(self, A):
        # write code here
        larr = []
        for i in range(len(A)):
            if i==0:
                larr.append(1)
            else:
                larr.append(A[i-1]*larr[i-1])
        rarr = []
        for i in reversed(range(len(A))):
            if i==len(A)-1:
                rarr.append(1)
            else:
                rarr =[A[i+1]*rarr[0]] +rarr
        B = []
        
        for i in range(len(A)):
            B.append(larr[i]*rarr[i])
        return B
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值