C++實(shí)現(xiàn)LeetCode(170.兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì))
[LeetCode] 170. Two Sum III - Data structure design 兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)
Design and implement a TwoSum class. It should support the following operations: add and find.
add - Add the number to an internal data structure.
find - Find if there exists any pair of numbers which sum is equal to the value.
Example 1:
add(1); add(3); add(5);
find(4) -> true
find(7) -> false
Example 2:
add(3); add(1); add(2);
find(3) -> true
find(6) -> false
這道題讓我們?cè)O(shè)計(jì)一個(gè) Two Sum 的數(shù)據(jù)結(jié)構(gòu),跟 LeetCode 的第一道題 Two Sum 沒(méi)有什么太大的區(qū)別,作為 LeetCode 的首題,Two Sum 的名氣不小啊,正所謂平生不會(huì) TwoSum,刷盡 LeetCode 也枉然。記得原來(lái)在背單詞的時(shí)候,總是記得第一個(gè)單詞是 abandon,結(jié)果有些人背來(lái)背去還在 abandon,有時(shí)候想想刷題其實(shí)跟背 GRE 紅寶書(shū)沒(méi)啥太大的區(qū)別,都是一個(gè)熟練功夫,并不需要有多高的天賦,只要下足功夫,都能達(dá)到一個(gè)很不錯(cuò)的水平,套用一句雞湯問(wèn)來(lái)激勵(lì)下吧,“有些時(shí)候我們的努力程度根本達(dá)不到需要拼天賦的地步”,好了,不閑扯了,來(lái)看題吧。不過(guò)這題也沒(méi)啥可講的,會(huì)做 Two Sum 的這題就很簡(jiǎn)單了,先來(lái)看用 HashMap 的解法,把每個(gè)數(shù)字和其出現(xiàn)的次數(shù)建立映射,然后遍歷 HashMap,對(duì)于每個(gè)值,先求出此值和目標(biāo)值之間的差值t,然后需要分兩種情況來(lái)看,如果當(dāng)前值不等于差值t,那么只要 HashMap 中有差值t就返回 True,或者是當(dāng)差值t等于當(dāng)前值時(shí),如果此時(shí) HashMap 的映射次數(shù)大于1,則表示 HashMap 中還有另一個(gè)和當(dāng)前值相等的數(shù)字,二者相加就是目標(biāo)值,參見(jiàn)代碼如下:
解法一:
class TwoSum {
public:
void add(int number) {
++m[number];
}
bool find(int value) {
for (auto a : m) {
int t = value - a.first;
if ((t != a.first && m.count(t)) || (t == a.first && a.second > 1)) {
return true;
}
}
return false;
}
private:
unordered_map<int, int> m;
};
另一種解法不用 HashMap,而是 unordered_multiset 來(lái)做,但是原理和上面一樣,參見(jiàn)代碼如下:
解法二:
class TwoSum {
public:
void add(int number) {
s.insert(number);
}
bool find(int value) {
for (auto a : s) {
int cnt = a == value - a ? 1 : 0;
if (s.count(value - a) > cnt) {
return true;
}
}
return false;
}
private:
unordered_multiset<int> s;
};
Github 同步地址:
https://github.com/grandyang/leetcode/issues/170
類似題目:
參考資料:
https://leetcode.com/problems/two-sum-iii-data-structure-design/
https://leetcode.com/problems/two-sum-iii-data-structure-design/discuss/52015/Beats-100-Java-Code
到此這篇關(guān)于C++實(shí)現(xiàn)LeetCode(170.兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì))的文章就介紹到這了,更多相關(guān)C++實(shí)現(xiàn)兩數(shù)之和之三 - 數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
VSCode搭建STM32開(kāi)發(fā)環(huán)境的方法步驟
當(dāng)我們的工程文件比較大的時(shí)候,編譯一次代碼需要很久可能會(huì)花費(fèi)到四五分鐘,但是我們用vscode編寫(xiě)和編譯的話時(shí)間就會(huì)大大縮減,本文就介紹一下VSCode搭建STM32開(kāi)發(fā)環(huán)境,感興趣的可以了解一下2021-07-07
如何在Qt中實(shí)現(xiàn)關(guān)于Json?的操作
JSON是一種輕量級(jí)數(shù)據(jù)交換格式,常用于客戶端和服務(wù)端的數(shù)據(jù)交互,不依賴于編程語(yǔ)言,在很多編程語(yǔ)言中都可以使用JSON,這篇文章主要介紹了在Qt中實(shí)現(xiàn)關(guān)于Json的操作,需要的朋友可以參考下2023-08-08
C++中的STL中map用法詳解(零基礎(chǔ)入門(mén))
map在編程中是經(jīng)常使用的一個(gè)容器,本文來(lái)講解一下STL中的map,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08
C語(yǔ)言sizeof和strlen的指針和數(shù)組面試題詳解
strlen是函數(shù),字符串長(zhǎng)度,不包括停止符。而sizeof則是內(nèi)存塊的大小,包括停止符。數(shù)組是一種數(shù)據(jù)類型,數(shù)據(jù)類型的本質(zhì)就是固定大小,內(nèi)存塊的別名。可以用sizeof()一般都是數(shù)據(jù)類型2022-04-04
C++實(shí)現(xiàn)LeetCode(168.求Excel表列名稱)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(168.求Excel表列名稱),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
最新VScode C/C++ 環(huán)境配置的詳細(xì)教程
這篇文章主要介紹了最新VScode C/C++ 環(huán)境配置的詳細(xì)教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11

