Leetcode 724 尋找陣列的中心索引

2021-08-29 18:06:52 字數 1171 閱讀 3642

給定乙個整數型別的陣列 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...