化簡無所不在! 用化簡來解 最大的對偶數。Leetcode #2441

閱讀時間約 2 分鐘

題目敘述

給定一個非零陣列nums,請找出陣列裡面 最大的對偶數 是誰?

如果無解,請返回-1


對偶數定義: 整數k的對偶數是-k

例如: 99 和 -99互為對偶數。


約束條件

Constraints:

  • 1 <= nums.length <= 1000

輸入陣列長度介於 1 ~ 1000 之間。

  • -1000 <= nums[i] <= 1000

每個元素值介於 -1000~1000之間。

  • nums[i] != 0

每個元素值都不等於0


演算法 化簡到Two-sum

跟著題目、範例思考,可以發現,其實這題就是Two sum兩數之和的變形。

原本兩數之和是在找 x + y = target

這邊特化成,找對偶的 x + (-x) = target = 0 目標值固定是0


基本想法是類似的,依序掃描每個元素,每次看過的數字記錄起來,遇到對偶數 -x的時候,更新對偶數的最大值,最後回傳最大的對偶數,就是答案。


程式碼 化簡到Two-sum

class Solution:
def findMaxK(self, nums: List[int]) -> int:

#記錄看過的數字
history = set()
maxNum = -1

for number in nums:

# 發現對偶數存在
if -number in history:

# 更新對偶數的最大值
maxNum = max( maxNum, abs(number) )

# 把看過的數字記錄下來
history.add(number)

return maxNum

複雜度分析

時間複雜度: O(n)

線性掃描,從左到右掃描每個陣列元素,總共耗時O(n)


空間複雜度: O(n)

建立了一個集合,大小最大為元素總數,所占空間為O(n)


關鍵知識點

尋找對偶數,相當於找兩數之和 x + y = 0, 且 y = -x

也可以說就是在找 x + (-x) = 0,並且找出所有解集合裡面x的最大值

可以回去複習兩數之和這題,兩題考的其實是同一個觀念。


Reference:

[1] Largest Positive Integer That Exists With Its Negative - LeetCode

82會員
417Content count
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
發表第一個留言支持創作者!
題目敘述 給定一個piles陣列,裡面對應到每堆石頭的數量。 Alice 和 Bob玩輪流取石頭的遊戲,總共有n堆石頭,每堆的石頭數量有多有少。 Alice先取,接著Bob,反覆交替,每回合輪到的人可以從當下的第一堆或者最後一堆,拿走那堆對應的石頭。 最後比誰拿到的石頭總數量比較多就獲勝。
在沙龍主頁面的右上角,現在多一個放大鏡圖案的搜尋介面。 裡面可以輸入你想看的主題、關鍵字或者Leetcode題號, 就可以找到相關的文章與演算法框架分析。 例如: 搜尋 DFS 搜尋 DP 搜尋 圖論 搜尋 Coin Change ... 歡迎舊雨新知多多利用!
演算法映射化簡的核心觀念 在面對新題目的時候,除了重頭想一個新的演算法之外; 還有另一個方法,想看看有沒有核心觀念彼此相同的問題與演算法, 如果有,就可以把新的題目映射化簡到已知解法的問題,用已知的演算法去解開。 接著,我們會介紹幾個範例,並且使用映射化簡的技巧來解題,透過化
給定一個Linked list鏈結串列的Head node, 請判斷這條Linked list是否存在環路(Cycle)? 如果有環路,回傳True。 如果沒有,回傳False。
這篇文章,會帶大家快速回顧DFS+回溯法框架(還沒看過或想複習的可以點連結進去)。 用DFS+回溯法框架,解開 組合數之和 Combination Sum 的全系列題目。 幫助讀者鞏固DFS+回溯法框架這個重要的知識點。 回顧 DFS+回溯法框架 白話的意思 # 列舉所以可能的情況,
這篇文章,會帶著大家複習以前學過的 格子點DP框架, 並且以最小成本的下降路徑的應用題與概念為核心, 貫穿一些相關聯的題目,透過框架複現來幫助讀者理解這個演算法框架。 最小成本下降路徑的形式 每個格子點的值代表經過的成本。 要求從最上面那排往下方走,落到最下一排的最小成本的下降路徑。
題目敘述 給定一個piles陣列,裡面對應到每堆石頭的數量。 Alice 和 Bob玩輪流取石頭的遊戲,總共有n堆石頭,每堆的石頭數量有多有少。 Alice先取,接著Bob,反覆交替,每回合輪到的人可以從當下的第一堆或者最後一堆,拿走那堆對應的石頭。 最後比誰拿到的石頭總數量比較多就獲勝。
在沙龍主頁面的右上角,現在多一個放大鏡圖案的搜尋介面。 裡面可以輸入你想看的主題、關鍵字或者Leetcode題號, 就可以找到相關的文章與演算法框架分析。 例如: 搜尋 DFS 搜尋 DP 搜尋 圖論 搜尋 Coin Change ... 歡迎舊雨新知多多利用!
演算法映射化簡的核心觀念 在面對新題目的時候,除了重頭想一個新的演算法之外; 還有另一個方法,想看看有沒有核心觀念彼此相同的問題與演算法, 如果有,就可以把新的題目映射化簡到已知解法的問題,用已知的演算法去解開。 接著,我們會介紹幾個範例,並且使用映射化簡的技巧來解題,透過化
給定一個Linked list鏈結串列的Head node, 請判斷這條Linked list是否存在環路(Cycle)? 如果有環路,回傳True。 如果沒有,回傳False。
這篇文章,會帶大家快速回顧DFS+回溯法框架(還沒看過或想複習的可以點連結進去)。 用DFS+回溯法框架,解開 組合數之和 Combination Sum 的全系列題目。 幫助讀者鞏固DFS+回溯法框架這個重要的知識點。 回顧 DFS+回溯法框架 白話的意思 # 列舉所以可能的情況,
這篇文章,會帶著大家複習以前學過的 格子點DP框架, 並且以最小成本的下降路徑的應用題與概念為核心, 貫穿一些相關聯的題目,透過框架複現來幫助讀者理解這個演算法框架。 最小成本下降路徑的形式 每個格子點的值代表經過的成本。 要求從最上面那排往下方走,落到最下一排的最小成本的下降路徑。
你可能也想看
Thumbnail
重點摘要: 1.9 月降息 2 碼、進一步暗示年內還有 50 bp 降息 2.SEP 上修失業率預期,但快速的降息速率將有助失業率觸頂 3.未來幾個月經濟數據將繼續轉弱,經濟復甦的時點或是 1Q25 季底附近
Thumbnail
近期的「貼文發佈流程 & 版型大更新」功能大家使用了嗎? 新版式整體視覺上「更加凸顯圖片」,為了搭配這次的更新,我們推出首次貼文策展 ❤️ 使用貼文功能並完成這次的指定任務,還有機會獲得富士即可拍,讓你的美好回憶都可以用即可拍珍藏!
Thumbnail
🍀🍀🍀fumi老師:❤️❤️❤ 🥰🥰🥰靈氣大師階的課程點化,是一開始會先探尋自己的內在世界,當同學看到「小王子」出現,是自己內在的形象展現,看得出來是一位充滿著赤子之心、保有童稚的溫暖療癒師。 💞💞💞在邁進靈氣大師的階段時,會是一個重新整理、重新整合自己的最棒的時機,你會看到自
Thumbnail
2020年開始,因新冠疫情肆虐,導致人心惶惶,自然界也沒有平靜過......。氣候變遷、海洋危機、森林大火、高溫乾旱等問題遍及全球各地,去年台灣更遭逢半世紀以來最慘的水荒!很明顯全球暖化引起的極端氣候已近在眼前。 自從歐洲工業革命以來,人類的工業活動大量燃燒煤炭、石油等化石燃料,而二氧化碳排放量也從
Thumbnail
昨天(11月21日)的過程是這樣,原本平緩的走勢,突然傳出了下面的新聞: 美媒稱OPEC考慮下月宣布增產 遭沙烏地否認 出現增產50萬桶的新聞後,油價急殺了5美元,然後又出現了沙國澄清否認的新聞,走勢就急彈回到原本平緩的位置。
Thumbnail
本次作品,是以中秋節和嫦娥為設計主軸,再搭配一些可愛的人物、動物來構圖,穿插一些小飾品,就可以構出一個具有個人風格的圖畫啦~ 有興趣的朋友也可以拿起自己的畫筆,就直接畫上去了,別想太多!
Thumbnail
在簡報、文案以至是文書來往的過程中,我們需要闡述論點之間的關係,層層推進直到結論,利用邏輯的架構及相關的證據,去加強訊息的說服力。然而直線前進的解說,還遠不及多角度、立體化的註解,所以我們就來看一下,在英語的環境如何話峰一轉吧。
Thumbnail
妳是否也有過這種情形? 每到一個季節就會有源源不絕新單品出現,逛街看到就心動地打包帶回家,但回到家後開始面對炸滿出來的衣櫃,亦或是趕時間想搭配但困擾無法快速辨別衣服,想實施衣櫃斷捨離但每件都是心頭肉下不了手,讓總總因素困擾著...然後就又過了一個季節...。
Thumbnail
中央流行疫情指揮中心日前宣布,8月24日至9月6日國內維持第2級疫情警戒,由於新冠肺炎本土疫情近日穩定,外界關注9月7日後是否有升降級考量。指揮中心指揮官陳時中今天透露,9月7日後沒有降級打算,但正在評估開放運動場所淋浴間及增加雙鐵運量。 中央流行疫情指揮中心下午召開疫情記者會,指揮中心指揮官陳時中
Thumbnail
很多人會說「在家工作會分不清楚什麼時候在工作」這句話只對了一半。另一半的答案要讓接案的人來答:「接案的人沒有上班和下班的時間,生活裡有工作,而工作也是生活的一部分!」
Thumbnail
園遊會,幾乎是每個台灣高中生生涯中難忘的一塊。當我們從課堂中學習了經濟模型、科技運用,從社團中學會了統籌規劃、分工合作,終於能在園遊會上,將所學、所思、所想付諸行動,相信對所有人都是一段難忘的回憶。 舉辦無塑園遊會(不是減塑而是「無塑」)對於任何高中都是一大難題,更別談在校生將近三千人的師大附中了
Thumbnail
重點摘要: 1.9 月降息 2 碼、進一步暗示年內還有 50 bp 降息 2.SEP 上修失業率預期,但快速的降息速率將有助失業率觸頂 3.未來幾個月經濟數據將繼續轉弱,經濟復甦的時點或是 1Q25 季底附近
Thumbnail
近期的「貼文發佈流程 & 版型大更新」功能大家使用了嗎? 新版式整體視覺上「更加凸顯圖片」,為了搭配這次的更新,我們推出首次貼文策展 ❤️ 使用貼文功能並完成這次的指定任務,還有機會獲得富士即可拍,讓你的美好回憶都可以用即可拍珍藏!
Thumbnail
🍀🍀🍀fumi老師:❤️❤️❤ 🥰🥰🥰靈氣大師階的課程點化,是一開始會先探尋自己的內在世界,當同學看到「小王子」出現,是自己內在的形象展現,看得出來是一位充滿著赤子之心、保有童稚的溫暖療癒師。 💞💞💞在邁進靈氣大師的階段時,會是一個重新整理、重新整合自己的最棒的時機,你會看到自
Thumbnail
2020年開始,因新冠疫情肆虐,導致人心惶惶,自然界也沒有平靜過......。氣候變遷、海洋危機、森林大火、高溫乾旱等問題遍及全球各地,去年台灣更遭逢半世紀以來最慘的水荒!很明顯全球暖化引起的極端氣候已近在眼前。 自從歐洲工業革命以來,人類的工業活動大量燃燒煤炭、石油等化石燃料,而二氧化碳排放量也從
Thumbnail
昨天(11月21日)的過程是這樣,原本平緩的走勢,突然傳出了下面的新聞: 美媒稱OPEC考慮下月宣布增產 遭沙烏地否認 出現增產50萬桶的新聞後,油價急殺了5美元,然後又出現了沙國澄清否認的新聞,走勢就急彈回到原本平緩的位置。
Thumbnail
本次作品,是以中秋節和嫦娥為設計主軸,再搭配一些可愛的人物、動物來構圖,穿插一些小飾品,就可以構出一個具有個人風格的圖畫啦~ 有興趣的朋友也可以拿起自己的畫筆,就直接畫上去了,別想太多!
Thumbnail
在簡報、文案以至是文書來往的過程中,我們需要闡述論點之間的關係,層層推進直到結論,利用邏輯的架構及相關的證據,去加強訊息的說服力。然而直線前進的解說,還遠不及多角度、立體化的註解,所以我們就來看一下,在英語的環境如何話峰一轉吧。
Thumbnail
妳是否也有過這種情形? 每到一個季節就會有源源不絕新單品出現,逛街看到就心動地打包帶回家,但回到家後開始面對炸滿出來的衣櫃,亦或是趕時間想搭配但困擾無法快速辨別衣服,想實施衣櫃斷捨離但每件都是心頭肉下不了手,讓總總因素困擾著...然後就又過了一個季節...。
Thumbnail
中央流行疫情指揮中心日前宣布,8月24日至9月6日國內維持第2級疫情警戒,由於新冠肺炎本土疫情近日穩定,外界關注9月7日後是否有升降級考量。指揮中心指揮官陳時中今天透露,9月7日後沒有降級打算,但正在評估開放運動場所淋浴間及增加雙鐵運量。 中央流行疫情指揮中心下午召開疫情記者會,指揮中心指揮官陳時中
Thumbnail
很多人會說「在家工作會分不清楚什麼時候在工作」這句話只對了一半。另一半的答案要讓接案的人來答:「接案的人沒有上班和下班的時間,生活裡有工作,而工作也是生活的一部分!」
Thumbnail
園遊會,幾乎是每個台灣高中生生涯中難忘的一塊。當我們從課堂中學習了經濟模型、科技運用,從社團中學會了統籌規劃、分工合作,終於能在園遊會上,將所學、所思、所想付諸行動,相信對所有人都是一段難忘的回憶。 舉辦無塑園遊會(不是減塑而是「無塑」)對於任何高中都是一大難題,更別談在校生將近三千人的師大附中了