中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

golang刷leetcode技巧之如何實現生存人數問題

發布時間:2021-12-15 09:52:12 來源:億速云 閱讀:142 作者:小新 欄目:大數據

這篇文章主要介紹了golang刷leetcode技巧之如何實現生存人數問題,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

給定N個人的出生年份和死亡年份,第i個人的出生年份為birth[i],死亡年份為death[i],實現一個方法以計算生存人數最多的年份。

你可以假設所有人都出生于1900年至2000年(含1900和2000)之間。如果一個人在某一年的任意時期都處于生存狀態,那么他們應該被納入那一年的統計中。例如,生于1908年、死于1909年的人應當被列入1908年和1909年的計數。

如果有多個年份生存人數相同且均為最大值,輸出其中最小的年份。

示例:

輸入:
birth = {1900, 1901, 1950}
death = {1948, 1951, 2000}
輸出: 1901

提示:

  • 0 < birth.length == death.length <= 10000

  • birth[i] <= death[i]

解題思路

1,這個題目和并行任務數是一樣的

2,出生+1,死亡-1

3,關鍵是繼承上一年的sum[i]+=sum[i-1]

4,注意有個坑,1909年死的人應該在1909年還算存活,1910年不算了

代碼實現

func maxAliveYear(birth []int, death []int) int {    sum:=make([]int,102)    for i:=0;i<len(birth);i++{        sum[birth[i]-1900]++    }    for i:=0;i<len(death);i++{        sum[death[i]-1899]--    }    max:=sum[0]    maxIndex:=0    for i:=1;i<102;i++{        sum[i]+=sum[i-1]        if sum[i]>max{            max=sum[i]            maxIndex=i        }    }    return 1900+maxIndex    //1909年死的人應該在1909年還算存活,1910年不算了,,沒理解好,所以應該是102大小的數組}

感謝你能夠認真閱讀完這篇文章,希望小編分享的“golang刷leetcode技巧之如何實現生存人數問題”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

齐齐哈尔市| 溆浦县| 山丹县| 兰西县| 沁阳市| 锡林郭勒盟| 金山区| 洪泽县| 图木舒克市| 宝兴县| 云浮市| 孙吴县| 九寨沟县| 西峡县| 岢岚县| 和田县| 颍上县| 肃宁县| 西和县| 辽宁省| 北海市| 银川市| 安庆市| 衡南县| 潮安县| 广丰县| 蒙阴县| 沾化县| 龙口市| 日照市| 湖南省| 阳朔县| 诸暨市| 凌源市| 微博| 廊坊市| 扶风县| 惠水县| 蚌埠市| 河北区| 淮阳县|