[LeetCode] 1. Two Sum 兩數之和

来源:https://www.cnblogs.com/HappyLion-ve/archive/2018/10/09/9762146.html
-Advertisement-
Play Games

Part 1. 題目描述 (easy) Given an array of integers, return indices of the two numbers such that they add up to a specific target. You may assume that each ...


Part 1. 題目描述 (easy)

Given an array of integers, return indices of the two numbers such that they add up to a specific target.

You may assume that each input would have exactly one solution, and you may not use the same element twice.

Example

Given nums = [2, 7, 11, 15], target = 9, because nums[0] + nums[1] = 2 + 7 = 9, return [0, 1].

Part 2. 分析

 本題是LeetCode的第一題,求解題目並不難,但是如何進一步優化時間複雜度是本題的重點。需要用到的基礎是hash table,在python中可以用字典來實現。

Part 3. 解決方案

【方法1: 暴力求解 (Brute Force)】

 最簡單直接的求解方式,遍歷所有兩個數的組合,將兩數之和跟target的值進行比較。時間複雜度O(n2),空間複雜度O(1)。

 python 代碼如下:

1 class Solution:
2     def twoSum(self, nums, target):
3         for i in range(len(nums)):
4             for j in range(i+1, len(nums)):
5                 if nums[i] + nums[j] == target:
6                     return [i, j]

【方法2: One-pass Hash Table】

如果我們想要降低時間複雜度,該如何解決呢?我們可以藉助hash函數來實現,因為它可以免除了第二輪的遍歷過程,使搜索時間變為O(1),總的時間複雜度降低為O(n)。但相應的,其空間複雜度會變複雜,變為O(n)。

python 代碼如下:

1 class Solution:
2     def twoSum(self, nums, target):
3         dict_nums = {}   # key: num  values: index
4         for i in range(len(nums)):
5             rest = target - nums[i]
6             if rest in dict_nums:
7                 return [dict_nums[rest], i]
8             dict_nums[nums[i]] = i

備註:註意判斷hash中是否存在需要的數字(line 5-7)和添加新數字到hash中(line 8)的順序,如果反過來寫,某些case會出錯,比如nums = [3,3,1,4], target = 6. 因為在hash中,我們將數字作為key來存儲,這要求key是唯一的。如果我們先執行存儲操作的話,當出現2個相同數字的時候就會報錯。

Part 4. 心得體會 

       剛開始接觸LeetCode,想通過刷演算法題的方法把演算法、數據結構的基礎知識好好鞏固一番。因為主要不是為了面試而刷題,所以做題順序上可以更隨心所欲一些。準備先做top 100的題目,然後其餘的題目順序待定。編程語言準備以python為主,雖然java、C++都用過,但是都沒有到熟練掌握的程度。因為以後可能更多的會用python來做實驗,所以正好這回多寫點python程式,提升代碼水平,希望自己能堅持下去咯!

       完事開頭難,這一題雖然是easy級別的,但是自己在第一次寫暴力求解代碼的時候還是粗心出了錯,腦子有點跟不上節奏啊......在學習方法2的時候,因為對python字典不怎麼瞭解,還花時間去學習了字典的基本操作。再加上這是我第一次在博客上寫技術的東西(以前都是私底下用有道筆記),所以花了不少時間,但是已經從中感受到樂趣啦。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Introduce(介紹) 用戶簽到的H5例子(css+jquery,無圖片),由於網上找的的用戶簽到例子都不好,要不就是好多圖片組成的,要不就大量冗餘代碼,所以特意做了個簽到界面(移動端)。 User sign sample page for mobile using h5 which only ...
  • 先安裝 axios axios的詳細介紹以及用法 就不多說了請 移步 github ➡️ https://github.com/axios/axios 下麵是簡單的封裝一個 http.js, 在此說明 checkStatus 這個方法呢 是不一定需要的 ,根據個人的項目需求吧,也可以直接返回resp ...
  • JS中的typeof方法可以查看數據的類型,如下: 1 console.log(typeof 2); // number 2 console.log(typeof "2"); // string 3 console.log(typeof true); // boolean 4 console.log ...
  • 關於使用css製作三角符號,網上有很多的例子了,在這裡只是為了詳細的向各位解釋一下三角符號的原理 下圖,是一個長寬為100px,邊框寬度為100px的一個元素,由此可見,在css中上下左右的邊框相交處並不是一個直線,所以,可以根據此屬性進行編寫三角符號 那麼如何使用css的該屬性來實現三角符號的效果 ...
  • push() 在數組末尾添加一個元素 pop() 在數組末尾刪除一個元素 shift() 刪除數組第一個元素 unshift 在數組開頭添加一個元素 concat() 方法用於連接兩個或多個數組 splice() 刪除、插入、替換 1、刪除功能,第一個參數為第一項位置,第二個參數為要刪除幾個。arr ...
  • Infi-chu: http://www.cnblogs.com/Infi-chu/ CSS盒子模型 概念:CSS盒模型本質上是一個盒子,封裝周圍的HTML元素,它包括:邊距,邊框,填充,和實際內容。盒模型允許我們在其它元素和周圍元素邊框之間的空間放置元素。 如下所示: 不同部分的說明: Margi ...
  • Westore Cloud 隱形雲,NoBackEnd,NoSql,HiddenDB 好的設計便是感覺不到設計的存在 開發小程式,但是:沒有後端!沒有運維!沒有 DBA!沒有功能變數名稱!沒有證書!沒有錢!沒有精力! 沒關係,會 javascript 就可以,Westore Cloud 帶你起飛~~ Git ...
  • 最近有了個新需求,swiper3d橫向滾動多張炫酷切換banner要和elementUI裡邊走馬燈的卡片化card 類似,但是還需要h5手機觸摸滾動啊啊啊啊,昨天折騰了半個早上總算完成,今天乖乖跑來mark一下。一眨眼過了一個月,9月這段期間項目多,還帶著小徒弟做項目,一邊教還要一邊趕進度。真的是超 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...