【LeetCode】每日一題:三數之和

解題思路

最開始是打算沿著二數之和的思路做,即固定了最大的,然后小的開始遍歷,因為這種遍歷方式只需要遍歷一輪就能完成,所以復雜度應該是O(n2),但是最后幾個示例還是超時了,可能進一步優化還是可以做的。但是事實上,我最開始就在尋找一個能夠約束剩余兩個變量的方法,因為不重復我們可以添加大小關系的假設,但是腦子里一直是兩個指針在一個遍歷中移動所以沒搞出來。事實上是,一個變量變大,另一個變量的上限減小,可以基于這個想法做。

未AC代碼,最后樣例超時

class Solution:def threeSum(self, nums: List[int]) -> List[List[int]]:def get_res(index, k):disk = {}res = []for i, n in enumerate(nums[:index]):if n <= - k // 2:if n == -k // 2 and n in disk and n + n + k == 0:res.append([n, n, k])    disk[-k - n] = ielse:if n in disk:res.append([n, - n - k, k])return resres = []nums.sort()for i in range(-1, -len(nums) - 1, -1):temp = get_res(i, nums[i])for t in temp:if t not in res:res.append(t)return res

官方題解

class Solution:def threeSum(self, nums: List[int]) -> List[List[int]]:n = len(nums)nums.sort()ans = list()# 枚舉 afor first in range(n):# 需要和上一次枚舉的數不相同if first > 0 and nums[first] == nums[first - 1]:continue# c 對應的指針初始指向數組的最右端third = n - 1target = -nums[first]# 枚舉 bfor second in range(first + 1, n):# 需要和上一次枚舉的數不相同if second > first + 1 and nums[second] == nums[second - 1]:continue# 需要保證 b 的指針在 c 的指針的左側while second < third and nums[second] + nums[third] > target:third -= 1# 如果指針重合,隨著 b 后續的增加# 就不會有滿足 a+b+c=0 并且 b<c 的 c 了,可以退出循環if second == third:breakif nums[second] + nums[third] == target:ans.append([nums[first], nums[second], nums[third]])return ans

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/36069.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/36069.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/36069.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

《UDS協議從入門到精通》系列——圖解0x35:請求上傳

《UDS協議從入門到精通》系列——圖解0x35&#xff1a;請求上傳 一、簡介二、數據包格式2.1 服務請求格式2.2 服務響應格式2.2.1 肯定響應2.2.2 否定響應 三、通信示例 Tip&#x1f4cc;&#xff1a;本文描述中但凡涉及到其他UDS服務的&#xff0c;將陸續提供鏈接跳轉方式以便快…

解決Java中的NoSuchElementException異常的常見方法

解決Java中的NoSuchElementException異常的常見方法 大家好&#xff0c;我是免費搭建查券返利機器人省錢賺傭金就用微賺淘客系統3.0的小編&#xff0c;也是冬天不穿秋褲&#xff0c;天冷也要風度的程序猿&#xff01;在Java編程中&#xff0c;NoSuchElementException異常是一個…

AMSR-E/Aqua 第 3 級全球地表土壤水分月平均值 V005 (AMSRE_AVRMO)

AMSR-E/Aqua level 3 global monthly Surface Soil Moisture Averages V005 (AMSRE_AVRMO) at GES DISC AMSR-E/Aqua level 3 global monthly Surface Soil Moisture Standard Deviation V005 (AMSRE_STDMO) at GES DISC 簡介 GES DISC 的 AMSR-E/Aqua 第 3 級全球地表土壤水…

操作系統入門 -- 內存管理

操作系統入門 – 內存管理 1.內存種類 1.1 虛擬內存&#xff08;VIRT&#xff09; 進程需要的虛擬內存大小&#xff0c;包括進程使用的庫、代碼、數據以及malloc、new分配的堆空間和棧空間等。若進程申請了10MB內存但實際使用了1MB&#xff0c;則物理空間會增長10MB。 1.2 …

Resource punkt not found.的解決方法

這個問題本來不想記錄&#xff0c;但是在好幾個機子上都碰到了&#xff08;用到了LangChain讀Word文檔&#xff09;。簡單記錄一下。看到報錯以后運行&#xff1a; import nltk # nltk.set_proxy(http://192.168.1.68:10811) nltk.download() 中間這句我注釋掉了&#xff0c;…

接軌國際安全標準:等保認證在提升企業全球競爭力中的核心作用

隨著全球化進程的加速和數字經濟的蓬勃發展&#xff0c;信息安全已成為企業拓展國際市場、參與國際競爭的重要基石。網絡安全等級保護&#xff08;簡稱“等保”&#xff09;認證&#xff0c;作為衡量企業信息安全管理水平的重要標尺&#xff0c;不僅體現了企業的技術實力和合規…

速盾:ddos攻擊類型有哪些?

DDoS攻擊&#xff08;分布式拒絕服務攻擊&#xff09;是一種通過利用多個被感染的計算機或網絡設備&#xff0c;以大量的請求或數據包來占用目標系統資源&#xff0c;導致其無法正常提供服務的攻擊方式。DDoS攻擊常常被黑客用來影響目標的可用性&#xff0c;造成經濟損失或打擊…

如何以智能方式安裝 Python

Python易于使用&#xff0c;對初學者友好&#xff0c;功能強大&#xff0c;幾乎可以為任何應用程序創建強大的軟件。 但與任何其他軟件一樣&#xff0c;Python 的設置和管理可能很復雜。 在本文中&#xff0c;我們將介紹如何正確設置 Python。 您將學習如何選擇合適的版本、…

學習筆記——動態路由——RIP(附加度量值配置)

六、附加度量值配置 RIP協議cost開銷值&#xff1a;默認值為0&#xff0c;路由信息每傳遞一次&#xff0c;值增加1&#xff0c;最大15,(路由器不能超過15臺)16代表不可達。 入接口附加度量值 rip metricin 5 //可以修改開銷改變路徑。只能增加&#xff0c;不能減小 …

count(*) over (partition by ……)用法詳解

select id,count(*) over(partition by pro_id) from sal; 以pro_id分組&#xff0c;統計分組后每個pro_id的記錄總數及對應的id&#xff1b; 類似還有count(*) over(order by ……)、sum(amount) over(partition by ……)等&#xff0c;略有區別

降低企業運營成本的API服務有哪些?

通過API服務&#xff0c;企業可以實現許多功能和服務的自動化和優化&#xff0c;從而有效降低企業的運營成本。API服務可以幫助企業簡化流程、減少人工操作、提高效率&#xff0c;并提供數據支持和決策依據&#xff0c;從而實現成本的有效控制和降低。無論是人力資源管理、客戶…

【D3.js in Action 3 精譯】1.2.2 可縮放矢量圖形(一)

譯注 由于 1.2.2 小節介紹 SVG 的篇幅過多&#xff0c;為了方便查閱&#xff0c;后續將分多個小節依次進行翻譯。為了確保整個 1.2.2 小節的完整性&#xff0c;特意將上一篇包含的 SVG 小節的內容整理出來重新編排。敬請留意。 1.2.2 SVG - 可縮放矢量圖形 可伸縮矢量圖形&…

kaoYan-English

英語的提高是個日積月累&#xff0c;可以花一個月時間突擊政治。但英語不可。關鍵在于單詞和閱讀理解 提高英語成績的捷徑&#xff0c;多做閱讀題。閱讀理解的分值高&#xff0c;閱讀理解在鞏固詞匯&#xff0c;培養語感有不可替代作用。 選資料&#xff0c;貼合考研難度的&a…

x264 編碼器 i_intra_cost 計算過程

介紹 是uint16_t類型指針變量,用來存儲每個宏塊的幀內代價值,在 frame.h 文件中x264_frame_t結構體中聲明。在*frame_new 函數中將lowres_costs[0][0]指向給i_intra_cost,并 memset 為-1;//代碼有刪減 frame->i_intra_cost = frame->lowres_costs[0][0]; memset( fra…

Raspbian命令行連接WiFi網絡

Raspbian命令行連接WiFi網絡 1. 源由2. 環境3. 信號4. 連接5. 檢查6. 斷開 1. 源由 “懶人”多福&#xff0c;是什么原因&#xff0c;大家知道不&#xff0c;哈哈。 如果大家關注過之前《Ardupilot開源代碼之Rover上路計劃》&#xff0c;為了筆記本電腦在不斷網的情況下進行配…

Rust 中使用 :: 這種語法的幾種情況

文章目錄 1. 訪問模塊成員&#xff1a;2. 訪問關聯函數或靜態方法&#xff1a;3. 訪問 trait 的關聯類型或關聯常量4. 指定泛型類型參數 1. 訪問模塊成員&#xff1a; mod utils {pub fn do_something() { /* ... */ } }let result utils::do_something();2. 訪問關聯函數或靜…

【Spring Cloud Alibaba AI】簡單使用

本文基于官方文檔。 Spring AI 官方文檔&#xff1a;Spring AI :: Spring AI Reference 中文文檔&#xff1a;Spring AI 簡介 - spring 中文網 (springdoc.cn) Spring AI 是 Spring 官方社區項目&#xff0c;旨在簡化 Java AI 應用程序開發&#xff0c;讓 Java 開發者像使用…

達夢數據庫死鎖排查和解決

達夢數據庫死鎖排查和解決 鏈接: 達夢數據庫死鎖排查和解決

道路元素位置和方向的坐標系統: 點 線 面 連接點

道路元素位置和方向的坐標系統: 下圖道路元素在地球坐標系中的位置&#xff0c;該位置由三個坐標軸&#xff08;x, y, z&#xff09;組成的笛卡爾坐標系來確定。這種描述特別適用于三維建模和地理信息系統&#xff08;GIS&#xff09;中&#xff0c;其中道路被視為一個三維模型…

XSLT 轉換:深入解析與實際應用

XSLT 轉換:深入解析與實際應用 引言 XSLT(Extensible Stylesheet Language Transformations)是一種用于將XML文檔轉換為其他格式(如HTML、XML或文本)的語言。它由W3C制定,是XML技術棧的重要組成部分。XSLT轉換不僅限于格式轉換,還可以用于數據提取、報告生成、復雜計算…