剑指 Offer 66. 构建乘积数组

题目:

给定一个数组 A[0,1,…,n-1],请构建一个数组 B[0,1,…,n-1],其中 B[i] 的值是数组 A 中除了下标 i 以外的元素的积, 即 B[i]=A[0]×A[1]×…×A[i-1]×A[i+1]×…×A[n-1]。不能使用除法。

 

示例:

输入: [1,2,3,4,5]
输出: [120,60,40,30,24]

 

提示:

  • 所有元素乘积之和不会溢出 32 位整数
  • a.length <= 100000

 

代码:

//分两次乘,一次得到i前面的乘积,一次的到i后面的乘积。

复制代码
 1 class Solution {
 2     public int[] constructArr(int[] a) {
 3         int len = a.length;
 4         int[] res=new int[len];
 5         int temp=1;
 6         //从后往前乘
 7         for(int i=0;i<len;i++){
 8             res[i]=temp;
 9             temp*=a[i];
10         }
11         temp=1;
12         //从前往后乘
13         for(int i=len-1;i>=0;i--){
14             res[i]*=temp;
15             temp*=a[i];
16         }
17        
18        return res;
19     }
20 }
复制代码

 

 

posted @   堤苏白  阅读(27)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 字符编码:从基础到乱码解决
· 提示词工程——AI应用必不可少的技术
点击右上角即可分享
微信分享提示