题解 | #相等的草堆#
相等的草堆
https://www.nowcoder.com/practice/0e2f3b27bbdc45fcbc70cc4fd41e15fe
考察数组操作。遍历数组分别讨论每个值的左右和去判断就行了。用一个数记录总和,两个数组分别记录每个数左右两侧的和。判断这两个数组相同位置是否有相同的值
完整Java代码如下所示
import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * * @param nums int整型一维数组 * @return int整型 */ public int pivotIndex (int[] nums) { // write code here int[] left = new int[nums.length]; //存储每个元素左侧的草堆总重量 int[] right = new int[nums.length]; //存储每个元素右侧的草堆总重量 int res = -1; for(int i=1;i<nums.length; i++){ //跳过最开端的一个 left[i] = left[i-1]+nums[i-1]; } for(int i=nums.length-1;i>0; i--){ //跳过最后面的一个 right[i-1] = right[i]+nums[i]; } for(int i=0; i<nums.length; i++){ if(left[i]==right[i]){ return i; } } return res; } }