本篇文章和大家了解一下java如何尋找數(shù)組中心索引。有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)大家有所幫助。
在臨桂等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專(zhuān)注、極致的服務(wù)理念,為客戶(hù)提供成都網(wǎng)站制作、成都做網(wǎng)站 網(wǎng)站設(shè)計(jì)制作按需策劃,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),營(yíng)銷(xiāo)型網(wǎng)站建設(shè),外貿(mào)網(wǎng)站制作,臨桂網(wǎng)站建設(shè)費(fèi)用合理。目的:
給定一個(gè)整數(shù)類(lèi)型的數(shù)組 nums,請(qǐng)編寫(xiě)一個(gè)能夠返回?cái)?shù)組“中心索引”的方法。
數(shù)組中心索引定義:
數(shù)組中心索引的左側(cè)所有元素相加的和等于右側(cè)所有元素相加的和。如果數(shù)組不存在中心索引,那么我們應(yīng)該返回 -1。如果數(shù)組有多個(gè)中心索引,那么我們應(yīng)該返回最靠近左邊的那一個(gè)。
示例1:
輸入: nums = [1, 7, 3, 6, 5, 6] 輸出: 3 解釋: 索引3 (nums[3] = 6) 的左側(cè)數(shù)之和(1 + 7 + 3 = 11),與右側(cè)數(shù)之和(5 + 6 = 11)相等。 同時(shí), 3 也是第一個(gè)符合要求的中心索引。
示例2:
輸入: nums = [1, 2, 3] 輸出: -1 解釋: 數(shù)組中不存在滿足此條件的中心索引。
說(shuō)明:
nums 的長(zhǎng)度范圍為 [0, 10000]。
任何一個(gè) nums[i] 將會(huì)是一個(gè)范圍在 [-1000, 1000]的整數(shù)。
解決思路:
利用sum、leftSum, rightSum分別存放總和,i左側(cè)和,i右側(cè)和,先算出一個(gè)總sum來(lái)是為了下面計(jì)算方便,然后移動(dòng)一個(gè)從左到右的i,注意i在第一個(gè)元素時(shí)需要單獨(dú)考慮。分別算出i左邊還有右邊的值然后比對(duì),如果leftSum=rightSum,就返回i。
java代碼:
class Solution { public int pivotIndex(int[] nums) { if (nums == null || nums.length == 0) { return -1; } int sum = 0; int leftSum = 0; int rightSum = 0; for (int i = 0; i < nums.length; i++) { sum += nums[i]; } for (int i = 0; i < nums.length; i++) { if (i == 0) { leftSum = 0; } else { leftSum += nums[i - 1]; } rightSum = sum - leftSum - nums[i]; if (leftSum == rightSum) { return i; } } return -1; } }
以上就是java如何尋找數(shù)組中心索引的簡(jiǎn)略介紹,當(dāng)然詳細(xì)使用上面的不同還得要大家自己使用過(guò)才領(lǐng)會(huì)。如果想了解更多,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道哦!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。