238. Product of Array Except Self
by Botao Xiao
238. Product of Array Except Self
Question
Given an array nums of n integers where n > 1, return an array output such that output[i] is equal to the product of all the elements of nums except nums[i].
Example:
Input: [1,2,3,4]
Output: [24,12,8,6]
Note:
- The linked list will have at least two elements.
- All of the nodes’ values will be unique.
- The given node will not be the tail and it will always be a valid node of the linked list.
- Do not return anything from your function.
Thinking:
- Method 1:
- 先存储左侧的乘积。
- 再存储右侧的乘积。
class Solution {
public int[] productExceptSelf(int[] nums) {
int len = nums.length;
int[] result = new int[len];
for(int i = 0, temp = 1; i < len; i++){
result[i] = temp;
temp *= nums[i];
}
for(int i = len - 1, temp = 1; i >= 0; i--){
result[i] *= temp;
temp *= nums[i];
}
return result;
}
}
二刷
- Method 1:
- We use a same size array to save the production of left side(exclude itself).
- Then we traverse the array from end to top and time the values saved in the array to save the product of right side.
- For each number, we actually times the left product with right product(itself is not included).
class Solution { public int[] productExceptSelf(int[] nums) { int len = nums.length; int[] result = new int[len]; for(int i = 0, temp = 1; i < len; i++){ result[i] = temp; temp *= nums[i]; } for(int i = len - 1, temp = 1; i >= 0; i--){ result[i] *= temp; temp *= nums[i]; } return result; } }
Amazon session
class Solution {
public int[] productExceptSelf(int[] nums) {
// result for a number = production of left * production of right
int len = nums.length;
if(len == 0) return new int[0];
int[] left = new int[len], right = new int[len];
left[0] = 1;
right[0] = 1;
for(int i = 1; i < len; i++){
left[i] = nums[i - 1] * left[i - 1];
}
right[len - 1] = 1;
for(int i = len - 2; i >= 0; i--){
right[i] = nums[i + 1] * right[i + 1];
}
int[] res = new int[len];
for(int i = 0; i < len; i++) res[i] = left[i] * right[i];
return res;
}
}
Subscribe via RSS