每日一题:LeetCode之除自身以外数组的乘积

给你一个长度为 n 的整数数组 nums,其中 n > 1,返回输出数组 output ,其中 output[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积。

示例:

输入: [1,2,3,4]
输出: [24,12,8,6]

说明: 请不要使用除法,且在 O(n) 时间复杂度内完成此题。

思路:用数组保存该索引左边乘积和右边乘积,一次遍历数组

 public int[] productExceptSelf(int[] nums) {
        int[] left=new int[nums.length];
 

        
        for(int i=0;i<nums.length;i++){
            if(i==0)
                left[i]=1;
            else
                left[i]=left[i-1]*nums[i-1];
        }
        int r=1;
        for(int i=nums.length-1;i>=0;i--){
            int t=nums[i];
            nums[i]=left[i]*r;
            r=r*t;
        }
        
        return nums;
    }
发布了28 篇原创文章 · 获赞 0 · 访问量 365

猜你喜欢

转载自blog.csdn.net/qq_40053995/article/details/105124793
今日推荐