LeetCode 169. 求眾數(shù) Majority Element

【題目描述】
給定一個大小為 n 的數(shù)組,找到其中的眾數(shù)。眾數(shù)是指在數(shù)組中出現(xiàn)次數(shù)大于 ? n/2 ? 的元素。
你可以假設數(shù)組是非空的析命,并且給定的數(shù)組總是存在眾數(shù)。

【示例1】

輸入: [3,2,3]
輸出: 3

【示例2】

輸入: [2,2,1,1,1,2,2]
輸出: 2

【思路1】哈希表
1伊滋、遍歷一遍 遍歷一遍數(shù)組 使用map記錄
2碳却、返回次數(shù)大于 ? n/2 ? 的元素
3、時間復雜度O(n)
4笑旺、空間復雜度O(n)

func majorityElement(_ nums: [Int]) -> Int {
    var map = [Int:Int]()
    for num in nums {
        var value = map[num] ?? 0
        value+=1
        map[num] = value
    }
    for (k,v) in map {
        if v > nums.count/2 {
            return k
        }
    }
    return 0
}

【思路2】排序
1昼浦、如果所有單調(diào)遞增或者單調(diào)遞減的數(shù)組,那么這個數(shù)組的眾數(shù)為arr[ ? n/2 ?]
2筒主、時間復雜度O(nlogn)
3关噪、空間復雜度O(n)
4、LeetCode上內(nèi)部給的例子報錯乌妙!

func majorityElement(_ nums: [Int]) -> Int {
    let arr = nums.sorted()
    return arr[nums.count/2]
}

【思路3】抵消思想使兔,也叫摩爾投票算法 <這個想法好牛??>
1、初始化 眾數(shù) num 和 count
2藤韵、遍歷數(shù)組虐沥,我們假設第一個數(shù)就是眾數(shù) num
3、當是眾數(shù)的時泽艘,count+1欲险,是其他數(shù)時 count-1,當count==0時匹涮,下一個數(shù)又被當成是眾數(shù)天试,依次遍歷數(shù)組,這樣來回抵消然低,最后count肯定會大于1喜每,那么返回最后的num即可
4、時間復雜度O(n) 線性時間
5雳攘、空間復雜度O(1)

func majorityElement(_ nums: [Int]) -> Int {
    var count = 0
    var tmp = 0
    for num in nums {
        if count == 0 {
            tmp = num
        }
        count+=(tmp == num) ? 1 : -1
    }
    return tmp
}
``
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末带兜,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子吨灭,更是在濱河造成了極大的恐慌鞋真,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,188評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件沃于,死亡現(xiàn)場離奇詭異涩咖,居然都是意外死亡,警方通過查閱死者的電腦和手機繁莹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,464評論 3 395
  • 文/潘曉璐 我一進店門檩互,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人咨演,你說我怎么就攤上這事闸昨。” “怎么了薄风?”我有些...
    開封第一講書人閱讀 165,562評論 0 356
  • 文/不壞的土叔 我叫張陵饵较,是天一觀的道長。 經(jīng)常有香客問我遭赂,道長循诉,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,893評論 1 295
  • 正文 為了忘掉前任撇他,我火速辦了婚禮茄猫,結果婚禮上,老公的妹妹穿的比我還像新娘困肩。我一直安慰自己划纽,他們只是感情好,可當我...
    茶點故事閱讀 67,917評論 6 392
  • 文/花漫 我一把揭開白布锌畸。 她就那樣靜靜地躺著勇劣,像睡著了一般。 火紅的嫁衣襯著肌膚如雪潭枣。 梳的紋絲不亂的頭發(fā)上比默,一...
    開封第一講書人閱讀 51,708評論 1 305
  • 那天,我揣著相機與錄音卸耘,去河邊找鬼退敦。 笑死,一個胖子當著我的面吹牛蚣抗,可吹牛的內(nèi)容都是我干的侈百。 我是一名探鬼主播,決...
    沈念sama閱讀 40,430評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼翰铡,長吁一口氣:“原來是場噩夢啊……” “哼钝域!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起锭魔,我...
    開封第一講書人閱讀 39,342評論 0 276
  • 序言:老撾萬榮一對情侶失蹤例证,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后迷捧,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體织咧,經(jīng)...
    沈念sama閱讀 45,801評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡胀葱,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,976評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了笙蒙。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片抵屿。...
    茶點故事閱讀 40,115評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖捅位,靈堂內(nèi)的尸體忽然破棺而出轧葛,到底是詐尸還是另有隱情,我是刑警寧澤艇搀,帶...
    沈念sama閱讀 35,804評論 5 346
  • 正文 年R本政府宣布尿扯,位于F島的核電站,受9級特大地震影響焰雕,放射性物質(zhì)發(fā)生泄漏衷笋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,458評論 3 331
  • 文/蒙蒙 一淀散、第九天 我趴在偏房一處隱蔽的房頂上張望右莱。 院中可真熱鬧,春花似錦档插、人聲如沸慢蜓。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,008評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽晨抡。三九已至,卻和暖如春则剃,著一層夾襖步出監(jiān)牢的瞬間耘柱,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,135評論 1 272
  • 我被黑心中介騙來泰國打工棍现, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留调煎,地道東北人。 一個月前我還...
    沈念sama閱讀 48,365評論 3 373
  • 正文 我出身青樓己肮,卻偏偏與公主長得像士袄,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子谎僻,可洞房花燭夜當晚...
    茶點故事閱讀 45,055評論 2 355

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