欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

[LeetCode] 136.Single Number 單獨(dú)的數(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

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

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

 異或運(yùn)算的真值表如下:

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

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

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++實(shí)現(xiàn)LeetCode(136.單獨(dú)的數(shù)字)的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)單獨(dú)的數(shù)字內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

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

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

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

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

    在C語言中,有時(shí)候我們遇到這樣的考題,將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ì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C語言構(gòu)建動(dòng)態(tài)數(shù)組完整實(shí)例

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

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

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

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

    使用C語言編寫一個(gè)強(qiáng)制關(guān)機(jī)程序

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

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

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

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

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

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

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

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

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

最新評(píng)論