题解 | #除自身以外数组的乘积#

除自身以外数组的乘积

http://www.nowcoder.com/practice/0786aa81c1c64c2a990e393fac811b45

题意:
        

方法一:
前缀积+后缀积

思路:
        遍历数组,分别计算前缀积和后缀积。
        计算公式如下:
        





class Solution {
public:
    int a[1000005]={1};
    int b[1000005]={0};
    vector<int> timesExceptSelf(vector<int>& nums) {
        int n=nums.size();
        vector<int> res(n);
        
        for(int i=1;i<=n;i++){
            a[i]=a[i-1]*nums[i-1];
        }
        b[n+1]=1;
        for(int i=n;i>=1;i--){
            b[i]=b[i+1]*nums[i-1];
        }
        for(int i=1;i<=n;i++){
            res[i-1]=a[i-1]*b[i+1];
        }
        return res;
    }
};


时间复杂度:
空间复杂度:

方法二:
空间优化

思路:
        针对方法一的空间优化:
            去除前缀积数组和后缀积数组,只用必要数组res进行前缀运算和后缀运算。

class Solution {
public:
    
    vector<int> timesExceptSelf(vector<int>& nums) {
        int n=nums.size();
        vector<int> res(n,1);//初始化
        
        for(int i=1;i<n;i++){//计算前缀积
            res[i]=res[i-1]*nums[i-1];
        }
        int t=1;
        for(int i=n-2;i>=0;i--){//计算后缀积
            t*=nums[i+1];
            res[i]*=t;
        }
        return res;
    }
};


时间复杂度:
空间复杂度:




全部评论

相关推荐

03-15 00:45
已编辑
中国科学院大学 Java
问的很简单都秒了,但是面试官没开摄像头,疑似kpi,无后续。--------------------3/14更新,3/12通知给了口头offer,3/13发了意向书,已拒。一面(35min)(25/3/6)(无后续)&nbsp;&nbsp;&nbsp;&nbsp;1、自我介绍&nbsp;&nbsp;&nbsp;&nbsp;2、介绍一下你的那个Python相关项目(本科毕设,web系统+算法模型提供部分接口)&nbsp;&nbsp;&nbsp;&nbsp;3、Java面向对象有哪些特点呢?详细说一下。&nbsp;&nbsp;&nbsp;&nbsp;4、介绍一下hashmap;为什么要把链表转换为红黑树呢?红黑树查找的时间复杂度?1.7和1.8的区别。&nbsp;&nbsp;&nbsp;&nbsp;5、介绍一下concurrentHashmap。&nbsp;&nbsp;&nbsp;&nbsp;6、synchronized锁和Lock锁有什么区别?&nbsp;&nbsp;&nbsp;&nbsp;7、公平锁的一个底层是怎么实现的呢?&nbsp;&nbsp;&nbsp;&nbsp;8、线程池的核心参数、拒绝策略、提交一个任务执行流程?&nbsp;&nbsp;&nbsp;&nbsp;9、spring有哪些特点?(ioc/aop)&nbsp;&nbsp;&nbsp;&nbsp;10、spring中对于循环依赖是怎么解决的?&nbsp;&nbsp;&nbsp;&nbsp;11、MySQL和redis的区别?&nbsp;&nbsp;&nbsp;&nbsp;12、MySQL的索引结构是什么?&nbsp;&nbsp;&nbsp;&nbsp;13、MySQL的事务有哪些特性?怎么保证?&nbsp;&nbsp;&nbsp;&nbsp;14、MySQL的默认隔离级别?可重复读是怎么做到的呢?&nbsp;&nbsp;&nbsp;&nbsp;15、介绍一下MVCC和快照读readview。&nbsp;&nbsp;&nbsp;&nbsp;16、一般在什么场景下会使用redis?&nbsp;&nbsp;&nbsp;&nbsp;17、对于大量的请求,如果此时缓存中还没有写入数据怎么办?&nbsp;&nbsp;&nbsp;&nbsp;18、介绍一下redis实现的分布式锁。&nbsp;&nbsp;&nbsp;&nbsp;19、有用过es和mongo&nbsp;DB吗?(知道,没用过)&nbsp;&nbsp;&nbsp;&nbsp;20、消息中间件用过吗?说一下你的使用场景?&nbsp;&nbsp;&nbsp;&nbsp;21、一个场景,如果说有一个接口响应的比较慢,如果说让你排查,你会怎么去排查?(上下游接口、大key问题,只答了两,后面试官补充)&nbsp;&nbsp;&nbsp;&nbsp;无手撕,反问业务。
胖墩墩的查理在学c语言:哥们我是五号面的 流程差不多
查看21道真题和解析
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务