亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++實現(xiàn)LeetCode(169.求大多數(shù))

 更新時間:2021年08月02日 14:50:11   作者:Grandyang  
這篇文章主要介紹了C++實現(xiàn)LeetCode(169.求大多數(shù)),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下

[LeetCode] 169. Majority Element 求大多數(shù)

Given an array nums of size n, return the majority element.

The majority element is the element that appears more than ⌊n / 2⌋ times. You may assume that the majority element always exists in the array.

Example 1:

Input: nums = [3,2,3]
Output: 3

Example 2:

Input: nums = [2,2,1,1,1,2,2]
Output: 2

Constraints:

  • n == nums.length
  • 1 <= n <= 5 * 104
  • -231 <= nums[i] <= 231 - 1

Follow-up: Could you solve the problem in linear time and in O(1) space?

這是到求大多數(shù)的問題,有很多種解法,其中我感覺比較好的有兩種,一種是用哈希表,這種方法需要 O(n) 的時間和空間,另一種是用一種叫摩爾投票法 Moore Voting,需要 O(n) 的時間和 O(1) 的空間,比前一種方法更好。這種投票法先將第一個數(shù)字假設為過半數(shù),然后把計數(shù)器設為1,比較下一個數(shù)和此數(shù)是否相等,若相等則計數(shù)器加一,反之減一。然后看此時計數(shù)器的值,若為零,則將下一個值設為候選過半數(shù)。以此類推直到遍歷完整個數(shù)組,當前候選過半數(shù)即為該數(shù)組的過半數(shù)。不仔細弄懂摩爾投票法的精髓的話,過一陣子還是會忘記的,首先要明確的是這個叼炸天的方法是有前提的,就是數(shù)組中一定要有過半數(shù)的存在才能使用,下面來看本算法的思路,這是一種先假設候選者,然后再進行驗證的算法?,F(xiàn)將數(shù)組中的第一個數(shù)假設為過半數(shù),然后進行統(tǒng)計其出現(xiàn)的次數(shù),如果遇到同樣的數(shù),則計數(shù)器自增1,否則計數(shù)器自減1,如果計數(shù)器減到了0,則更換下一個數(shù)字為候選者。這是一個很巧妙的設定,也是本算法的精髓所在,為啥遇到不同的要計數(shù)器減1呢,為啥減到0了又要更換候選者呢?首先是有那個強大的前提存在,一定會有一個出現(xiàn)超過半數(shù)的數(shù)字存在,那么如果計數(shù)器減到0了話,說明目前不是候選者數(shù)字的個數(shù)已經(jīng)跟候選者的出現(xiàn)個數(shù)相同了,那么這個候選者已經(jīng)很 weak,不一定能出現(xiàn)超過半數(shù),此時選擇更換當前的候選者。那有可能你會有疑問,那萬一后面又大量的出現(xiàn)了之前的候選者怎么辦,不需要擔心,如果之前的候選者在后面大量出現(xiàn)的話,其又會重新變?yōu)楹蜻x者,直到最終驗證成為正確的過半數(shù),佩服算法的提出者啊,代碼如下:

C++ 解法一:

class Solution {
public:
    int majorityElement(vector<int>& nums) {
        int res = 0, cnt = 0;
        for (int num : nums) {
            if (cnt == 0) {res = num; ++cnt;}
            else (num == res) ? ++cnt : --cnt;
        }
        return res;
    }
};

Java 解法一:

public class Solution {
    public int majorityElement(int[] nums) {
        int res = 0, cnt = 0;
        for (int num : nums) {
            if (cnt == 0) {res = num; ++cnt;}
            else if (num == res) ++cnt;
            else --cnt;
        }
        return res;
    }
}

下面這種解法利用到了位操作 Bit Manipulation 來解,將這個大多數(shù)按位來建立,從0到31位,每次統(tǒng)計下數(shù)組中該位上0和1的個數(shù),如果1多,那么將結果 res 中該位變?yōu)?,最后累加出來的 res 就是過半數(shù)了,相當贊的方法,參見代碼如下:

C++ 解法二:

class Solution {
public:
    int majorityElement(vector<int>& nums) {
        int res = 0, n = nums.size();
        for (int i = 0; i < 32; ++i) {
            int ones = 0, zeros = 0;
            for (int num : nums) {
                if (ones > n / 2 || zeros > n / 2) break;
                if ((num & (1 << i)) != 0) ++ones;
                else ++zeros;
            }
            if (ones > zeros) res |= (1 << i);
        }
        return res;
    }
};

Java 解法二:

public class Solution {
    public int majorityElement(int[] nums) {
        int res = 0, n = nums.length;
        for (int i = 0; i < 32; ++i) {
            int ones = 0, zeros = 0;
            for (int num : nums) {
                if (ones > n / 2 || zeros > n / 2) break;
                if ((num & (1 << i)) != 0) ++ones;
                else ++zeros;
            }
            if (ones > zeros) res |= (1 << i);
        }
        return res;
    }
}

Github 同步地址:

https://github.com/grandyang/leetcode/issues/169

類似題目:

Majority Element II

參考資料:

https://leetcode.com/problems/majority-element/

https://leetcode.com/problems/majority-element/discuss/51613/O(n)-time-O(1)-space-fastest-solution

https://leetcode.com/problems/majority-element/discuss/51612/6-Suggested-Solutions-in-C++-with-Explanations

https://leetcode.com/problems/majority-element/discuss/51611/Java-solutions-(sorting-hashmap-moore-voting-bit-manipulation).

https://leetcode.com/problems/majority-element/discuss/51828/C++-solution-using-Moore's-voting-algorithm-O(n)-runtime-comlexity-an-no-extra-array-or-hash-table

到此這篇關于C++實現(xiàn)LeetCode(169.求大多數(shù))的文章就介紹到這了,更多相關C++實現(xiàn)求大多數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • c++使用Easyx圖形庫實現(xiàn)飛機大戰(zhàn)

    c++使用Easyx圖形庫實現(xiàn)飛機大戰(zhàn)

    本文詳細講解了c++使用Easyx圖形庫實現(xiàn)飛機大戰(zhàn),文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • C語言學習筆記之VS2022安裝使用教程

    C語言學習筆記之VS2022安裝使用教程

    這篇文章主要介紹了C語言學習筆記之VS2022安裝使用教程,在VS2022中,在使用scanf函數(shù)編譯出錯,本文給大家提到了解決方法,需要的朋友可以參考下
    2022-05-05
  • C語言 動態(tài)內存分配的詳解及實例

    C語言 動態(tài)內存分配的詳解及實例

    這篇文章主要介紹了C語言 動態(tài)內存分配的詳解及實例的相關資料,需要的朋友可以參考下
    2016-09-09
  • 使用C語言實現(xiàn)從avi視頻中提取圖片

    使用C語言實現(xiàn)從avi視頻中提取圖片

    這篇文章主要為大家詳細介紹了如何使用C語言實現(xiàn)從avi視頻中提取圖片,文中的示例代碼簡潔易懂,具有一定的借鑒價值,有需要的小伙伴可以參考下
    2023-10-10
  • C++實現(xiàn)String類實例代碼

    C++實現(xiàn)String類實例代碼

    這篇文章主要介紹了C++實現(xiàn)String類實例代碼的相關資料,需要的朋友可以參考下
    2017-04-04
  • C語言 sprintf 函數(shù)詳情

    C語言 sprintf 函數(shù)詳情

    這篇文章主要介紹了C語言 sprintf 函數(shù),文章主要包括sprintf 函數(shù)簡介、sprintf 函數(shù)使用和簡單說明了一下sprintf、fprintf、printf 函數(shù)區(qū)別,需要的朋友可以參考一下文章的具體內容
    2021-10-10
  • C++11中異常處理機制詳解

    C++11中異常處理機制詳解

    傳統(tǒng)的C語言處理異常的方式有兩種:終止程序和返回錯誤碼。在實際中的C語言程序基本都是通過返回錯誤碼的方式來處理錯誤的,部分情況下使用終止程序來處理比較嚴重的錯誤。本文將通過示例和大家聊聊C++11中異常處理機制,需要的可以參考一下
    2022-09-09
  • C++實現(xiàn)雙向鏈表

    C++實現(xiàn)雙向鏈表

    這篇文章主要為大家詳細介紹了C++實現(xiàn)雙向鏈表,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 詳解C++調用Python腳本中的函數(shù)的實例代碼

    詳解C++調用Python腳本中的函數(shù)的實例代碼

    這篇文章主要介紹了C++調用Python腳本中的函數(shù) ,需要的朋友可以參考下
    2018-11-11
  • c++中cin/cout與scanf/printf的區(qū)別比較

    c++中cin/cout與scanf/printf的區(qū)別比較

    這篇文章主要介紹了c++中cin/cout與scanf/printf的區(qū)別比較,需要的朋友可以參考下
    2017-06-06

最新評論