python3 兩數之和

2021-10-13 05:42:32 字數 1126 閱讀 7926

給定乙個整數陣列 nums 和乙個目標值 target,請你在該陣列中找出和為目標值的那 兩個 整數,並返回他們的陣列下標。

你可以假設每種輸入只會對應乙個答案。但是,陣列中同乙個元素不能使用兩遍。

示例:給定 nums = [2, 7, 11, 15], target = 9

因為 nums[0] + nums[1] = 2 + 7 = 9

所以返回 [0, 1]

我寫的**:

class solution:

@classmethod

def twosum(cls, nums, target):

for i in nums:

if target - i in nums:

if i != target - i:

return [nums.index(i), nums.index(target - i)]

elif nums.count(i) > 1:

index1 = nums.index(i)

nums.remove(i)

return [index1, nums.index(i) + 1]

print(solution.twosum([1, 2, 4, 5], 6))

print(solution.twosum([3, 2, 4], 6))

print(solution.twosum([3, 3], 6))

上面查詢有冗餘,官方的簡潔**:

兩層迴圈時間複雜度為o(n2), 更好的辦法是雜湊表:

class solution:

def twosum(self, nums: list[int], target: int) -> list[int]:

hashtable = dict()

for i, num in enumerate(nums):

if target - num in hashtable:

return [hashtable[target - num], i]

hashtable[nums[i]] = i

return

需要注意:

1. 乙個元素不能使用兩遍

2. 重複元素的組合

Leetcode 兩數之和 python3

第一次寫部落格,也是記錄在leetcode上開始做題的時刻。class solution object def twosum self,nums,target dict for index,num in enumerate nums index是索引,num是內容 進行遍歷 if target nu...

1 兩數之和(python3)

題目 給定乙個整數陣列 nums 和乙個目標值 target,請你在該陣列中找出和為目標值的那 兩個 整數,並返回他們的陣列下標。你可以假設每種輸入只會對應乙個答案。但是,你不能重複利用這個陣列中同樣的元素。示例 給定 nums 2,7,11,15 target 9 因為 nums 0 nums 1...

python 兩數之和

給定乙個整數陣列 nums和乙個整數目標值 target,請你在該陣列中找出和為目標值的那兩個整數,並返回它們的陣列下標。你可以假設每種輸入只會對應乙個答案。但是,陣列中同乙個元素不能使用兩遍。def twosum nums,tatget hashmap for ind,num in enumera...