博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(剑指Offer)面试题52:构建乘积数组
阅读量:5076 次
发布时间:2019-06-12

本文共 1629 字,大约阅读时间需要 5 分钟。

题目:

给定一个数组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]。不能使用除法。

思路:

方法1:

直接连乘n-1个数,得到B[i];

时间复杂度:O(n^2)

方法2:

构建前向乘积数组C[i]=A[0]*A[1]*...*A[i-1],即C[i]=C[i-1]*A[i-1];

构建后向乘积数组D[i]=A[n-1]*A[n-2]*...A[n-i+1],即D[i]=D[i+1]*A[i+1];

通过C[i],D[i]来求B[i]:B[i]=C[i]*D[i]

时间复杂度:O(n)

代码:

void multiply(const vector
& array1,vector
& array2){ int len1=array1.size(); int len2=array2.size(); if(len1==len2 && len2>1){ array2[0]=1; for(int i=1;i
=0;i--){ tmp*=array1[i+1]; array2[i]*=tmp; } }}

在线测试OJ:

http://www.nowcoder.com/books/coding-interviews/94a4d381a68b47b7a8bed86f2975db46?rp=3

AC代码:

class Solution {public:    vector
multiply(const vector
& A) { int len=A.size(); if(len<1) return vector
(); vector
B(len,1); for(int i=1;i
=0;i--){ tmp*=A[i+1]; B[i]*=tmp; } return B; }};
class Solution {public:    vector
multiply(const vector
& A) { int len=A.size(); if(len<1) return vector
(); vector
B(len,1); vector
front(len,1); vector
back(len,1); for(int i=1;i
=0;i--){ back[i]=back[i+1]*A[i+1]; } for(int i=0;i

转载于:https://www.cnblogs.com/AndyJee/p/4693172.html

你可能感兴趣的文章
解决 No Entity Framework provider found for the ADO.NET provider
查看>>
设置虚拟机虚拟机中fedora上网配置-bridge连接方式(图解)
查看>>
ES6内置方法find 和 filter的区别在哪
查看>>
Android实现 ScrollView + ListView无滚动条滚动
查看>>
java学习笔记之String类
查看>>
UVA 11082 Matrix Decompressing 矩阵解压(最大流,经典)
查看>>
硬件笔记之Thinkpad T470P更换2K屏幕
查看>>
iOS开发——缩放图片
查看>>
HTTP之URL的快捷方式
查看>>
满世界都是图论
查看>>
配置链路聚合中极小错误——失之毫厘谬以千里
查看>>
蓝桥杯-分小组-java
查看>>
Android Toast
查看>>
iOS开发UI篇—Quartz2D使用(绘制基本图形)
查看>>
docker固定IP地址重启不变
查看>>
桌面图标修复||桌面图标不正常
查看>>
JavaScript基础(四)关于对象及JSON
查看>>
JAVA面试常见问题之Redis篇
查看>>
jdk1.8 api 下载
查看>>
getElement的几中属性介绍
查看>>