剑指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:构建乘积数组

//题目描述:给定一个数组A[0,1,...,n-1],请构建一个数组B[0,1,...,n-1], // 其中B中的元素B[i]=A[0]*A[1]*...*A[i-1]*...
  • crazyacm
  • crazyacm
  • 2016年04月02日 16:11
  • 259

【Java实现】剑指offer52--构建乘积数组

题目:  给定一个数组 A[0,1,...,n-1 ],请构建一个数组 B[0,1,...,n-1]     。 其中 B 中的元素 B[i]=A[0]∗ A[1] ∗...∗ A[i−1]∗A[i...
  • Rebirth_Love
  • Rebirth_Love
  • 2016年06月08日 13:08
  • 552

剑指_构建乘积数组

题目:给定一个数组A[0,1,......,n-1],请构建一个数组B[0,1,.......,n-1],其中B中的元素B[i]=A[0]*A[1]*.....*A[i-1]*A[i+1]*........
  • hlang8160
  • hlang8160
  • 2018年01月08日 18:37
  • 21

剑指offer——数组中重复的数字

问题描述:在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度为...
  • sbq63683210
  • sbq63683210
  • 2016年07月20日 16:03
  • 331

剑指Offer面试题33(java版):把数组排成最小的数

题目:输入一个正整数数组,把数组里面所有的数字拼接排成一个数,打印能拼接出的所有数字中的一个。例如输入数组{3,32,321},则打印出这3个数字能排成的最小数字321323. 这个题目最直接的做法...
  • jsqfengbao
  • jsqfengbao
  • 2015年08月09日 11:12
  • 2905

[剑指Offer]数组中重复的数字

题目描述: 在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。 例如,如果输入长度...
  • shakespeare001
  • shakespeare001
  • 2016年04月26日 17:20
  • 1507

构建乘积数组(Java实现)

本题为剑指offer面试题53 牛客网测试地址:https://www.nowcoder.com/questionTerminal/94a4d381a68b47b7a8bed86f2975db46 ...
  • zjkC050818
  • zjkC050818
  • 2017年05月29日 10:30
  • 661

剑指offer(37):数组中的逆序对

题目描述在数组中的两个数字,如果前面一个数字大于后面的数字,则这两个数字组成一个逆序对。输入一个数组,求出这个数组中的逆序对的总数。...
  • u011080472
  • u011080472
  • 2016年04月27日 16:21
  • 411

【剑指offer】数组中的逆序对

思路:最简单的方法是顺序数组,将每个数字与后面的比较,统计逆序对的个数,这种方法的时间复杂度为O(n*n),这种方法写出的代码在九度OJ上测试,会超时。剑指offer给出了归并排序的思路,这个有点难想...
  • mmc_maodun
  • mmc_maodun
  • 2014年05月30日 08:49
  • 4513

《剑指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]。不能使用...
  • shansusu
  • shansusu
  • 2015年11月07日 20:46
  • 258
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:剑指Offer--052-构建乘积数组
举报原因:
原因补充:

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