码迷,mamicode.com
首页 > 其他好文 > 详细

查找表_leetcode220

时间:2019-03-17 15:19:40      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:for   style   查找   leetcode   工作   sel   lse   remove   ica   

# 解题思路:用查找表(集合),保存其K个值的状态  遍历查找表时加上了限制条件T 20190302 找工作期间

class Solution(object):
def containsNearbyAlmostDuplicate(self, nums, k, t):
"""
:type nums: List[int]
:type k: int
:type t: int
:rtype: bool
"""
if len(nums) <= 1:
return False

if k<=0 or t < 0:
return False

record = set()
l = len(nums)

for i in range(l):
if t == 0:
if nums[i] in record:
return True
else:
for j in record:
if abs(nums[i]-j) <= t:
return True



record.add(nums[i])

if len(record) == k+1:
record.remove(nums[i-k])


return False


class Solution2(object):
def containsNearbyAlmostDuplicate(self, nums, k, t):
"""
:type nums: List[int]
:type k: int
:type t: int
:rtype: bool
"""
lenth = len(nums)
a = set()
for i in range(lenth):
if t==0:
if nums[i] in a:
return True
else:
for atem in a:
if abs(nums[i]-atem)<=t:
return True
a.add(nums[i])
if len(a) == k+1:
a.remove(nums[i-k])
return False

查找表_leetcode220

标签:for   style   查找   leetcode   工作   sel   lse   remove   ica   

原文地址:https://www.cnblogs.com/lux-ace/p/10546929.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!