剑指 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 }
· 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应用必不可少的技术