第一次写学习笔记,还有点生疏,就先写一道在书上学到的经典例题。既可以用双指针法,也可以用哈希算法求解
一、两个数的和
题目:要求在给定的数字中找出两个数,使得他们的和为N,返回两个数的编号
思路:我们将给定的数字放在一个数组中,设置目标值target,变成了在数组中寻找两个数之和为target,我们返回的是两个数字的编号,所以我们返回的是数是(数组下标+1)。
解题方法一(使用双指针进行数组的搜索,首先将数组从小到大排序,指针指向的两个数之和大于target,则右指针左移;指针指向的数之和小于target,则左指针右移;指针指向的两个数之和等于target,则返回(数组下标+1);当左指针大于右指针时,说明不存在正确的俩个数,返回-1)
def twosum(nums,target):
res = []
newnums = nums[:] # 深拷贝
newnums.sort()
left = 0 # 初始化左指针
right = len(newnums) - 1 # 初始化右指针
while left < right :
if newnums[left] + newnums[right] == target:
for i in range(0,len(nums)):
if nums[i] == newnums[left]:
res.append(i)
break
for i in range(len(nums)-1,-1,-1):
if nums[i] == newnums[right]:
res.append(i)
break
break
elif newnums[left] + newnums[right] > target:
right = right -1
elif newnums[left] + newnums[right] < target:
left = left + 1
else:
return -1
return (res[0]+1,res[1]+1)
解题方法二(使用哈希算法,建立字典来存放数据和下标的关系。本题如果我们给定其中一个数字m,那么问题其实可以转化为我们在数据集合中寻找另外一个数字(target-m),可以通过字典记录目前已经出现过哪些数字,这样每次出现一个新的数字的时候,就去字典中查找有没有对应的数字,如果有说明找到了,没有的话就把数字放到字典中,以备之后的查询使用)
def twosum2(nums,target): # 哈希算法
dict = {}
for i in range(len(nums)):
m = nums[i]
if target-m in dict:
return (dict[target-m]+1,i+1)
dict[m] = i