Python編程題5級 小明

本篇文章將從以下幾個方面對Python編程題5級 小明進行詳細闡述。

一、題目描述

小明最近學習了Python,並通過了Python編程題5級,他接下來想要練手,給定一個整數列表和一個目標值,請在列表中找到和為目標值的兩個整數,並返回它們的下標。假設每種輸入只會對應一個答案,但是你可以不按照任何順序返回答案。

def twoSum(nums: List[int], target: int) -> List[int]:
    pass

二、解題思路

1. 暴力枚舉

最暴力的方法當然是枚舉,這種方法的時間複雜度為O(n^2),並不是一個好的解法。

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        n = len(nums)
        for i in range(n):
            for j in range(i + 1, n):
                if nums[i] + nums[j] == target:
                    return [i, j]
        return []

2. 哈希表

使用哈希表可以降低時間複雜度,將時間複雜度降低為O(n),使用哈希表的思路就是維護一個映射關係,將每個數對應的下標存儲下來。

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        hashmap = {}
        for i, num in enumerate(nums):
            if target - num in hashmap:
                return [hashmap[target - num], i]
            hashmap[num] = i
        return []

解釋一下這段代碼,我們用一個字典來存儲每個數的下標,具體實現步驟如下:

1. 遍曆數組nums,將每個數num與對應的下標i插入字典hashmap中。

2. 遍曆數組nums,每次計算出還需要的target – num的值,如果在字典hashmap中出現過,就可以直接返回兩個數的下標。

注意:這種方法只能用於本題,如果是求解多數之和,哈希表就不是那麼好用了。

三、實踐運用

我們來用兩個例子來實踐運用上述兩種思路。

1. 暴力枚舉

給定nums = [2, 7, 11, 15], target = 9,期望輸出 [0, 1]。

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        n = len(nums)
        for i in range(n):
            for j in range(i + 1, n):
                if nums[i] + nums[j] == target:
                    return [i, j]
        return []

s = Solution()
print(s.twoSum([2, 7, 11, 15], 9)) # [0, 1]

2. 哈希表

給定nums = [2, 7, 11, 15], target = 9,期望輸出 [0, 1]。

class Solution:
    def twoSum(self, nums: List[int], target: int) -> List[int]:
        hashmap = {}
        for i, num in enumerate(nums):
            if target - num in hashmap:
                return [hashmap[target - num], i]
            hashmap[num] = i
        return []

s = Solution()
print(s.twoSum([2, 7, 11, 15], 9)) # [0, 1]

四、總結

本文從題目描述、解題思路與實踐運用三個方面對Python編程題5級 小明進行了詳細的闡述,希望本文能對Python編程愛好者有所幫助。

原創文章,作者:SNVEP,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/374952.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
SNVEP的頭像SNVEP
上一篇 2025-04-28 13:17
下一篇 2025-04-28 13:17

相關推薦

  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python清華鏡像下載

    Python清華鏡像是一個高質量的Python開發資源鏡像站,提供了Python及其相關的開發工具、框架和文檔的下載服務。本文將從以下幾個方面對Python清華鏡像下載進行詳細的闡…

    編程 2025-04-29
  • Python編程二級證書考試相關現已可以上網購買

    計算機二級Python考試是一項重要的國家級認證考試,也是Python編程的入門考試。與其他考試一樣,Python編程二級證書的考生需要進入正式考試,而為了備考,這篇文章將詳細介紹…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29
  • 蝴蝶優化演算法Python版

    蝴蝶優化演算法是一種基於仿生學的優化演算法,模仿自然界中的蝴蝶進行搜索。它可以應用於多個領域的優化問題,包括數學優化、工程問題、機器學習等。本文將從多個方面對蝴蝶優化演算法Python版…

    編程 2025-04-29
  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智慧、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29

發表回復

登錄後才能評論