剑指Offer--052-构建乘积数组

原创 2016年05月30日 21:04:03

链接


牛客OJ:构建乘积数组

九度OJ:未收录

GitHub代码: 052-构建乘积数组

CSDN题解:剑指Offer–052-构建乘积数组

牛客OJ 九度OJ CSDN题解 GitHub代码
052-构建乘积数组 未收录 剑指Offer–052-构建乘积数组 052-构建乘积数组

题意


题目描述

给定一个数组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, 2, 3, 4, 5]

样例输出

[120, 60, 40, 30, 24]

分析


那么对于新数组ans[i],我们从前往后遍历,可求得了A[1]A[2]…*A[i-1],

然后我们再从尾到头扫描一遍,对于当前第i位,我们任然按照前面的思想,累乘A[len-1]*…A[i+1]

例如:A[]={1,2,3}求B[]

B[0]=A[1]×A[2]=2×3=6

B[1]=A[0]×A[2]=1×3=3

B[2]=A[0]×A[1]=1×2=2

  1. B[0]初始化为1,从下标i=1开始,先求出C[i]的值并放入B[i],即B[i]=C[i]=C[i-1]×A[i-1],所以B[1]=B[1-1]×A[1-1]=B[0]×A[0]=1×1=1,i++

  2. B[2]=B[2-1]×A[2-1]=B[1]×A[1]=1×2=2,i++超出长度停止循环

  3. C[i]计算完毕求D[i],设置一个临时变量temp初始化为1

  4. 从后往前变量数组,LengthA=3初始化i=LengthA-2=1,结束条件为i>=0

  5. 第一次循环,temp=temp×A[i+1]=1×A[2]=3,计算出A中最后一个元素的值放入temp,temp相当于D[i]的值

  6. 因为之前的B[i]=C[i],所以让B[i]×D[i]就是要保存的结果,即B[i]=B[1]=B[1]×temp=1×3=3,i–=0

  7. 计算B[i]=B[0],temp上一步中的值是A[2],在这次循环中temp=temp×A[0+1]=A[2]×A[1]=3×2=6

  8. B[i]=B[0]=B0]×temp=1×6=6,i–<0循环结束

所以B数组为{6,3,2}

代码


#include <iostream>
#include <vector>

using namespace std;


//  调试开关
#define __tmain main

#ifdef __tmain

#define debug cout

#else

#define debug 0 && cout

#endif // __tmain


class Solution
{
public:
    vector<int> multiply(const vector<int>& A)
    {
        int n = A.size();
        vector<int> res(n);
        // C[i] = A[0] * A[1] * ... *A[i - 1]
        for(int i = 0, temp = 1; i < n; i++)
        {
            res[i] = temp;
            temp *= A[i];
        }

        // D[i] = A[i + 1] * A[i + 2] * ... *A[n - 1]
        for(int i = n - 1, temp = 1; i >= 0; i--)
        {
            res[i] *= temp;
            temp *= A[i];

        }
        return res;
    }
};

int __tmain( )
{
    debug <<"test" <<endl;
    return 0;
}
版权声明:本文为博主原创文章 && 转载请著名出处 @ http://blog.csdn.net/gatieme 举报

相关文章推荐

剑指Offer--052-构建乘积数组

链接 牛客OJ:构建乘积数组 九度OJ:http://ac.jobdu.com/problem.php?pid=1508 GitHub代码: 051-构建乘积数组 C...

《剑指offer》——构建乘积数组

T: 题目描述 给定一个数组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]。不能使用...

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

《剑指offer》:[52]构建乘积数组

题目:给定一个数组A[0,1,2...N-1],请构建一个数组B[0,1,2,...N-1],使B中的元素B[i]=A[0]*A[1]*...*A[i-1]*a[i+1]*...*a[n-1],不能使...
  • gogoky
  • gogoky
  • 2016-06-28 15:15
  • 1052

剑指offer——构建乘积数组

题目描述:给定一个数组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]。不能使用除法。思路:把前半部分...

构建乘积数组--剑指Offer

题目描述 : 给定一个数组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]。不能使...

剑指offer(54):构建乘积数组

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

构建乘积数组(利用辅助空间+剑指offer)

构建乘积数组 参与人数:890时间限制:1秒空间限制:32768K通过比例:37.82%最佳记录:0 ms|8552K(来自  Cry) 题目描述 给定一个数组A[0,1...

剑指offer-面试题52-构建乘积数组

package case52_ArrayConstruction; /** * 题目:给定一个数组A[0,1,2,...,N-1],请构建一个数组B[0,1,2,...,N-1],其中B中的元素:...

剑指offer46--乘积数组的构建

已知数组A,通过乘积的方式构建一个数组B,并将数组B进行返回

剑指Offer面试题52:构建乘积数组 Java实现

题目:构建乘积数组             给定一个数组A[0,1,2,……n-1],请构建一个数组B[0,1,……n-1],其中B中的元素B[i]=A[0]*A[1]*……A[i-1]*A[i+1...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)