阿里巴巴2017實(shí)習(xí)生春招編程測(cè)驗(yàn) —— 數(shù)組四等分

對(duì)于一個(gè)長(zhǎng)度為N的整型數(shù)組A, 數(shù)組里所有的數(shù)都是正整數(shù),對(duì)于兩個(gè)滿足0 <= X <= Y < N的整數(shù),A[X], A[X+1] … A[Y]構(gòu)成A的一個(gè)切片,記作(X, Y).
用三個(gè)下標(biāo) m1, m2, m3(下標(biāo)滿足條件0 < m1, m1 + 1 < m2, m2 +1 < m3 < N – 1)可以把這個(gè)整型數(shù)組分成(0, m1-1), (m1+1, m2-1), (m2+1, m3-1), (m3+1, N-1) 四個(gè)切片。
如果這四個(gè)切片的整數(shù)求和相等,稱作“四等分”。

編寫一個(gè)函數(shù),求一個(gè)給定的整型數(shù)組是否可以四等分,如果可以,返回一個(gè)布爾類型的true,如果不可以返回一個(gè)布爾類型的false。
限制條件:數(shù)組A最多有1,000,000項(xiàng),數(shù)組中的整數(shù)取值范圍介于-1,000,000到1,000,000之間。
要求:函數(shù)的計(jì)算復(fù)雜度為O(N),使用的額外存儲(chǔ)空間(除了輸入的數(shù)組之外)最多為O(N)。

例子:
對(duì)于數(shù)組A=[2, 5, 1, 1, 1, 1, 4, 1, 7, 3, 7] 存在下標(biāo) 2, 7, 9使得數(shù)組分成四個(gè)分片[2, 5], [1, 1, 1, 4], [7], [7],這三個(gè)分片內(nèi)整數(shù)之和相等,所以對(duì)于這個(gè)數(shù)組,函數(shù)應(yīng)該返回true。
對(duì)于數(shù)組 A=[10, 2, 11, 13, 1, 1, 1, 1, 1],找不到能把數(shù)組四等分的下標(biāo),所以函數(shù)應(yīng)該返回false。

今年參加了阿里的實(shí)習(xí)生春招,在進(jìn)行編程測(cè)驗(yàn)之前已經(jīng)了解到部分同學(xué)遇到的是這道題,所以事先做了準(zhǔn)備,然而輪到我時(shí)已經(jīng)換題了,可能是不同崗位題目不一樣吧。

這道題描述的啰哩啰嗦,實(shí)際上就是給一個(gè)全是正數(shù)的數(shù)組,問是否能將該數(shù)組分割成四部分,每一部分累加和相等,分割點(diǎn)不算

要解決這題首先要明確數(shù)組四等分的結(jié)構(gòu),即3個(gè)分割點(diǎn),4個(gè)切片,有了這個(gè)概念,在草紙上畫畫,問題很容易就解決了。

首先我們遍歷一遍數(shù)組構(gòu)造一個(gè)HashMap存儲(chǔ) ( arr[i]左邊所有元素的和 , i ) ,然后大多數(shù)人選擇讓分割點(diǎn)m1、m3從兩端像中間移動(dòng)的同時(shí)累加兩個(gè)切片內(nèi)元素(誰(shuí)小誰(shuí)移動(dòng)),當(dāng)兩個(gè)切片相等時(shí)根據(jù)四等分結(jié)構(gòu)看能否找到滿足條件的分割點(diǎn)m2。

這里我選擇僅將分割點(diǎn)m1由左向右移動(dòng),如果數(shù)組可以四等分,依據(jù)3個(gè)分割點(diǎn),4個(gè)切片這樣一個(gè)基本結(jié)構(gòu),一旦分割點(diǎn)m1確定了,m2、m3也就相應(yīng)確定了,如果最后找不到符合基本結(jié)構(gòu)的m2、m3,則可以斷定數(shù)組不可以四等分,時(shí)間復(fù)雜度O(N),代碼如下:

public static boolean canSplits(int[] arr) {
    if (arr == null || arr.length < 7) {    // 元素個(gè)數(shù)小于7,無(wú)法構(gòu)成3個(gè)分割點(diǎn)、4個(gè)切片的基本結(jié)構(gòu)
        return false;
    }
    HashMap<Long, Integer> leftSumToIndex = new HashMap<>();
    Long sum = (long) arr[0];
    for (int i = 1; i < arr.length; i++) {
        leftSumToIndex.put(sum, i);    // 把(arr[i]左邊所有元素的和, i)存入HashMap
        sum += arr[i];
    }
    Long part = (long) arr[0];         // part為切片內(nèi)元素的和
    for (int m1 = 1; m1 < arr.length - 5; m1++) {   // 遍歷分割點(diǎn)m1
        Long m2LeftSum = part + arr[m1] + part;     // 分割點(diǎn)m2左邊所有元素的和
        if (leftSumToIndex.containsKey(m2LeftSum)) {
            int m2 = leftSumToIndex.get(m2LeftSum);
            Long m3LeftSum = m2LeftSum + arr[m2] + part;  // 分割點(diǎn)m3左邊所有元素的和
            if (leftSumToIndex.containsKey(m3LeftSum)) {
                int m3 = leftSumToIndex.get(m3LeftSum);
                if (m3LeftSum + arr[m3] + part == sum) {
                    return true;
                }
            }
        }
        part += arr[m1];
    }
    return false;
}

對(duì)于像Two Sum、Longest Substring Without Repeating Characters以及本題這種涉及數(shù)組下標(biāo)的一系列問題,優(yōu)先考慮事先構(gòu)造一個(gè)HashMap看是否對(duì)后續(xù)的求解有幫助。在HashMap中,每次查詢操作的時(shí)間復(fù)雜度均為O(1),所以它一直是編寫高效算法的利器。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,406評(píng)論 6 538
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,034評(píng)論 3 423
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 177,413評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,449評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,165評(píng)論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,559評(píng)論 1 325
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,606評(píng)論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,781評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,327評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,084評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,278評(píng)論 1 371
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,849評(píng)論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,495評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,927評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,172評(píng)論 1 291
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,010評(píng)論 3 396
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,241評(píng)論 2 375

推薦閱讀更多精彩內(nèi)容

  • 貪心算法 貪心算法總是作出在當(dāng)前看來(lái)最好的選擇。也就是說(shuō)貪心算法并不從整體最優(yōu)考慮,它所作出的選擇只是在某種意義上...
    fredal閱讀 9,264評(píng)論 3 52
  • 來(lái)源:NumPy Tutorial - TutorialsPoint 譯者:飛龍 協(xié)議:CC BY-NC-SA 4...
    布客飛龍閱讀 32,930評(píng)論 6 98
  • 數(shù)組在程序設(shè)計(jì)中,為了處理方便, 把具有相同類型的若干變量按有序的形式組織起來(lái)。這些按序排列的同類數(shù)據(jù)元素的集合稱...
    朱森閱讀 3,970評(píng)論 2 13
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,807評(píng)論 18 139
  • 先決條件 在閱讀這個(gè)教程之前,你多少需要知道點(diǎn)python。如果你想從新回憶下,請(qǐng)看看Python Tutoria...
    舒map閱讀 2,597評(píng)論 1 13