給定乙個整數型別的陣列 nums,請編寫乙個能夠返回陣列「中心索引」的方法。
我們是這樣定義陣列中心索引的:陣列中心索引的左側所有元素相加的和等於右側所有元素相加的和。
如果陣列不存在中心索引,那麼我們應該返回 -1。如果陣列有多個中心索引,那麼我們應該返回最靠近左邊的那乙個。
示例 1:
輸入:nums = [1, 7, 3, 6, 5, 6]
輸出: 3
解釋:索引3 (nums[3] = 6) 的左側數之和(1 + 7 + 3 = 11),與右側數之和(5 + 6 = 11)相等。
同時, 3 也是第乙個符合要求的中心索引。
示例 2:
輸入:nums = [1, 2, 3]
輸出: -1
解釋:陣列中不存在滿足此條件的中心索引。
說明:nums 的長度範圍為 [0, 10000]。
任何乙個 nums[i] 將會是乙個範圍在 [-1000, 1000]的整數。
先分析題意:
取到乙個數,就判斷前面的和跟後邊的和是否相等,相等就返回這個下標;
其中,前後加和都不計算當前元素的值;
多個中心索引:可能都好幾個位置,前面的和都等於後邊的和;
public class pivotindex
int sumbefore =0;
for(int i=0;ii;j--)
if(numafter==sumbefore)
sumbefore=sumbefore+nums[i];
}return -1;
}}
和相等,就要反射出差值的關係;
右邊的總和=所有元素和-當前元素-左邊元素和;
每次判斷左邊和=右邊和;
class solution
int sum = 0;
for (int x : nums)
int leftsum = 0;
int rightsum = 0;
for (int i = 0; i < nums.length; i++)
leftsum = leftsum + nums[i];//這裡一定是先判斷結束後再加和左邊,因為每次判斷的值左邊和的值,不包含當前元素的值。
}return -1;
}}
Leetcode 724 尋找陣列的中心索引
題目 給定乙個整數型別的陣列 nums,請編寫乙個能夠返回陣列 中心索引 的方法。我們是這樣定義陣列中心索引的 陣列中心索引的左側所有元素相加的和等於右側所有元素相加的和。如果陣列不存在中心索引,那麼我們應該返回 1。如果陣列有多個中心索引,那麼我們應該返回最靠近左邊的那乙個。示例 1 輸入 num...
Leetcode 724 尋找陣列的中心索引
給定乙個整數型別的陣列 nums,請編寫乙個能夠返回陣列 中心索引 的方法。我們是這樣定義陣列中心索引的 陣列中心索引的左側所有元素相加的和等於右側所有元素相加的和。如果陣列不存在中心索引,那麼我們應該返回 1。如果陣列有多個中心索引,那麼我們應該返回最靠近左邊的那乙個。示例 1 輸入 nums 1...
Leetcode 724 尋找陣列的中心索引
題目描述 給定乙個整數型別的陣列nums,請編寫乙個能夠返回陣列 中心索引 的方法。我們是這樣定義陣列中心索引的 陣列中心索引的左側所有元素相加的和等於右側所有元素相加的和。如果陣列不存在中心索引,那麼我們應該返回 1。如果陣列有多個中心索引,那麼我們應該返回最靠近左邊的那乙個。示例 1 輸入 nu...