Leetcode 238. Product of Array Except Self

Given an array of n integers where n > 1, nums, return an array output such that output[i] is equal to the product of all the elements of nums except nums[i].

Solve it without division and in O(n).

For example, given [1,2,3,4], return [24,12,8,6].

Follow up: Could you solve it with constant space complexity? (Note: The output array does not count as extra space for the purpose of space complexity analysis.)

求一个数组除去每一个位置以后的乘积。不能用除法,O(n)时间复杂度,O(1)空间复杂度。

两个量分别统计前缀数组乘积和后缀数组乘积,每一个位置的值为前缀和后缀的乘积相乘。

class Solution {
public:
    vector<int> productExceptSelf(vector<int>& nums) {
        vector<int> res(nums.size(), 1);
        int s = 1, e = 1;
        int n = nums.size();
        for(int i = 0; i < nums.size(); i++)
        {
            res[i] *= s;
            s *= nums[i];
            res[n - 1 - i] *= e;
            e *= nums[n - 1 - i];
        }
        return res;
    }
};

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Hongten

java中的移位运算符:<<,>>,>>>总结

value >>> num     --   num 指定要移位值value 移动的位数。

23450
来自专栏个人分享

Scala第一章学习笔记

  面向对象编程是一种自顶向下的程序设计方法。用面向对象方法构造软件时,我们将代码以名词(对象)做切割,每个对象有某种形式的表示服(self/this)、行为(...

11620
来自专栏Python中文社区

Python装饰器探秘

add的功能是计算x和y的值,我们称作功能函数。 logger的作业是在执行add函数的同时再打印了其他的信息,这部分的作为add的功能增强,我们称为装饰。 在...

12010
来自专栏cmazxiaoma的架构师之路

Java数据结构和算法(2)--《Java数据结构和算法》第二版 Robert lafore第二章【数组】编码作业

21630
来自专栏指尖下的Android

二进制的运算

在计算机中存储字节是定长的,即我们8、16、32位等等,6的二进制位为110,但如果在8位计算机中是00000110,高位补零

25430
来自专栏猿人谷

获取对象属性类型、属性名称、属性值的研究:反射和JEXL解析引擎

先简单介绍下反射的概念:java反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动...

1.3K50
来自专栏大数据学习笔记

Java程序设计(Java9版):第2章 数据类型与运算符(Data types and Operators)

第2章 数据类型与运算符(Data types and Operators) I think everybody in this country should ...

28050
来自专栏Coding迪斯尼

java开发编译器:把C语言的循环指令编译成java字节码

20130
来自专栏算法修养

HDU 5421 Victor and String(回文树)

Victor and String Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 52428...

37060
来自专栏ml

poj------2406 Power Strings

A - Power Strings 难度:☆☆ Time Limit:3000MS     Memory Limit:65536KB     64bit I...

31880

扫码关注云+社区

领取腾讯云代金券