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

C++實現(xiàn)LeetCode(136.單獨的數(shù)字)

 更新時間:2021年07月19日 17:25:00   作者:Grandyang  
這篇文章主要介紹了C++實現(xiàn)LeetCode(136.單獨的數(shù)字),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

[LeetCode] 136.Single Number 單獨的數(shù)字

Given a non-empty array of integers, every element appears twice except for one. Find that single one.

Note:

Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?

Example 1:

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

Example 2:

Input: [4,1,2,1,2]
Output: 4

這道題給了我們一個非空的整數(shù)數(shù)組,說是除了一個數(shù)字之外所有的數(shù)字都正好出現(xiàn)了兩次,讓我們找出這個只出現(xiàn)一次的數(shù)字。題目中讓我們在線性的時間復(fù)雜度內(nèi)求解,那么一個非常直接的思路就是使用 HashSet,利用其常數(shù)級的查找速度。遍歷數(shù)組中的每個數(shù)字,若當(dāng)前數(shù)字已經(jīng)在 HashSet 中了,則將 HashSet 中的該數(shù)字移除,否則就加入 HashSet。這相當(dāng)于兩兩抵消了,最終凡事出現(xiàn)兩次的數(shù)字都被移除了 HashSet,唯一剩下的那個就是單獨數(shù)字了,參見代碼如下:

C++ 解法一:

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        unordered_set<int> st;
        for (int num : nums) {
            if (st.count(num)) st.erase(num);
            else st.insert(num);
        }
        return *st.begin();
    }
};

Java 解法一:

class Solution {
    public int singleNumber(int[] nums) {
        Set<Integer> st = new HashSet<>();
        for (int num : nums) {
            if (!st.add(num)) st.remove(num);
        }
        return st.iterator().next();
    }
}

題目中讓我們不使用額外空間來做,本來是一道非常簡單的題,但是由于加上了時間復(fù)雜度必須是 O(n),并且空間復(fù)雜度為 O(1),使得不能用排序方法,也不能使用 HashSet 數(shù)據(jù)結(jié)構(gòu)。那么只能另辟蹊徑,需要用位操作 Bit Operation 來解此題,這個解法如果讓我想,肯定想不出來,因為誰會想到用邏輯異或來解題呢。邏輯異或的真值表為:

 異或運算的真值表如下:

A B
F F F
F T T
T F T
T T F

由于數(shù)字在計算機是以二進(jìn)制存儲的,每位上都是0或1,如果我們把兩個相同的數(shù)字異或,0與0 '異或' 是0,1與1 '異或' 也是0,那么我們會得到0。根據(jù)這個特點,我們把數(shù)組中所有的數(shù)字都 '異或' 起來,則每對相同的數(shù)字都會得0,然后最后剩下來的數(shù)字就是那個只有1次的數(shù)字。這個方法確實很贊,但是感覺一般人不會往 '異或' 上想,絕對是為CS專業(yè)的同學(xué)設(shè)計的好題呀,贊一個~~ 

C++ 解法二:

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int res = 0;
        for (auto num : nums) res ^= num;
        return res;
    }
};

Java 解法二:

class Solution {
    public int singleNumber(int[] nums) {
        int res = 0;
        for (int num : nums) res ^= num;
        return res;
    }
}

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

相關(guān)文章

  • C++學(xué)習(xí)之Lambda表達(dá)式的用法詳解

    C++學(xué)習(xí)之Lambda表達(dá)式的用法詳解

    Lambda?表達(dá)式(lambda?expression)是一個匿名函數(shù),Lambda表達(dá)式基于數(shù)學(xué)中的λ演算得名。本文就來為大家詳細(xì)講講C++中Lambda表達(dá)式的使用,需要的可以參考一下
    2022-07-07
  • C語言中字母大小寫轉(zhuǎn)化簡單示例

    C語言中字母大小寫轉(zhuǎn)化簡單示例

    在C語言中,有時候我們遇到這樣的考題,將c語言大寫字母轉(zhuǎn)化為小寫字母,下面這篇文章主要給大家介紹了關(guān)于C語言中字母大小寫轉(zhuǎn)化的相關(guān)資料,文中介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11
  • C語言fprintf()函數(shù)和fscanf()函數(shù)的具體使用

    C語言fprintf()函數(shù)和fscanf()函數(shù)的具體使用

    本文主要介紹了C語言fprintf()函數(shù)和fscanf()函數(shù)的具體使用,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C語言構(gòu)建動態(tài)數(shù)組完整實例

    C語言構(gòu)建動態(tài)數(shù)組完整實例

    這篇文章主要介紹了C語言構(gòu)建動態(tài)數(shù)組完整實例,幫助讀者加深對C語言數(shù)組及指針的理解,需要的朋友可以參考下
    2014-07-07
  • C/C++指針介紹與使用詳解

    C/C++指針介紹與使用詳解

    不知從何時起對你一眼萬年,從此,每一天被賦予了特別的意義。時隔多年,依然揮之不去是你------指針?。?!本篇中幾乎數(shù)據(jù)類型只用了int,但是float、double等也是可以的
    2022-08-08
  • 使用C語言編寫一個強制關(guān)機程序

    使用C語言編寫一個強制關(guān)機程序

    這篇文章主要為大家詳細(xì)介紹了如何使用C語言實現(xiàn)一個簡單的"流氓軟件",一個可以強制關(guān)機惡作劇關(guān)機程序,輸入指定指令才可以解除,感興趣的小伙伴可以學(xué)習(xí)一下
    2023-11-11
  • VC++ 中ListCtrl經(jīng)驗總結(jié)

    VC++ 中ListCtrl經(jīng)驗總結(jié)

    這篇文章主要介紹了VC++ 中ListCtrl經(jīng)驗總結(jié)的相關(guān)資料,需要的朋友可以參考下
    2015-06-06
  • 詳解c++良好的編程習(xí)慣與編程要點

    詳解c++良好的編程習(xí)慣與編程要點

    c++語言的靈活是建立在對編程者個人的編程素質(zhì)的嚴(yán)格要求基礎(chǔ)上的,好的C++編程習(xí)慣能避免很多問題。沒有好的編程習(xí)慣,極有可能編寫一行代碼,編譯器能報十幾個錯誤,而且就算編譯通過了,將來在運行過程中也會有很多莫名奇妙的問題
    2021-06-06
  • Qt MQTT開發(fā)環(huán)境搭建的實現(xiàn)示例

    Qt MQTT開發(fā)環(huán)境搭建的實現(xiàn)示例

    本文主要介紹了Qt MQTT開發(fā)環(huán)境搭建的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • C++實踐數(shù)組類運算的實現(xiàn)參考

    C++實踐數(shù)組類運算的實現(xiàn)參考

    今天小編就為大家分享一篇關(guān)于C++實踐數(shù)組類運算的實現(xiàn)參考,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-02-02

最新評論