题解 | #构建乘积数组#

构建乘积数组

https://www.nowcoder.com/practice/94a4d381a68b47b7a8bed86f2975db46

前缀和思想,两遍遍历,第一遍计算前缀积,第二遍计算后缀积并与同一下标的前缀积相乘。

class Solution {
public:
    vector<int> multiply(const vector<int>& A) {
        int n = A.size();
        vector<int> res(A);
        for (int i = 1; i < n; i++) res[i] = res[i - 1] * A[i - 1];
        int r = A.back();
        for (int i = n - 2; i >= 0; i--) {
            res[i] *= r;
            r *= A[i];
        }
        return res;
    }
};

全部评论

相关推荐

爱吃肉的伊登在写日记:好棒,27届简历能做成这个样子,但是第一个项目感觉cover住难度还是不小的,特别是二面的时候肯定要对分布式系统设计这一块儿有高出正常面试者的水平才行
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务