import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param milk_amount int整型一维数组 * @return int整型一维数组 */ public int[] product_except_self (int[] milk_amount) { // write code here int index = -1; int sum = 1; for (int i = 0; i < milk_amount.length; i++) { if (milk_amount[i] == 0 && index == -1) { index = i; } else if (milk_amount[i] == 0 && index != -1) { return new int[milk_amount.length]; } else { sum *= milk_amount[i]; } } int[] arr = new int[milk_amount.length]; for (int i = 0; i < milk_amount.length; i++) { if (index==-1) { arr[i] = sum/milk_amount[i]; } else if(i==index) { arr[i] = sum; }else{ arr[i] = 0; } } return arr; } }
本题考察知识点是数组,所用编程语言是java。首先统计数组中0的个数和除0之外的乘积之和,
如果0的个数大于等于2,则返回一个全0的数组。
如果0的个数等于1,则除0所在位置之外的数都为0,0所在位置的数为前面所算的乘积之和
如果0的个数等于0,则每个位置的数为乘积之和除以milk_amount数组值