# 面试题53 在排序数组中查找数字
'''
三道题目都是二分查找的变式,当涉及到元素的值和下标的关系,而且又是查找,可以考虑下二分查找
'''
# 题目一:数字在排序数组中出现的次数
'''
方法1:利用二分查找,找到等于k的数字,然后向左向右顺序扫描,此时二分查找的复杂度是O(logn),顺序查找时O(n),所以总的复杂度是O(n)
方法2:同样是利用二分查找,但二分查找是找到重复数字的开始和末尾,不进行顺序扫描,所以复杂度是O(logn)
'''
class Solution:
def GetNumberOfK(self, data, k):
if not data:
return 0
number = 0
first = self.GetFirstK(data,k)
last = self.GetLastK(data,k)
if first >-1 and last > -1:
number = last -first +1
return number
def GetFirstK(self,data,k):
start, end = 0, len(data) - 1
while start <= end:
mid = int((start + end) / 2)
if data[mid]== k:
if (mid > 0 and data[mid - 1] != k) or mid == 0:
return mid
else:
end = mid - 1
elif data[mid] > k:
end = mid - 1
else:
start = mid + 1
return -1
def GetLastK(self,data,k):
start, end = 0, len(data) - 1
while start <= end:
mid = int((start + end) / 2)
if data[mid]== k:
if (mid < len(data) - 1 and data[mid + 1] != k) or mid == len(data) - 1:
return mid
else:
start = mid + 1
elif data[mid] > k:
end = mid - 1
else:
start = mid + 1
return -1
# 题目二 0~n-1中缺失的数字
class Solution2:
def GetMissingNumber(self,numbers):
if not numbers:
return -1
start, end = 0, len(numbers) - 1
while start <= end:
mid = int((start + end) / 2)
if numbers[mid] == mid:
# 此时下标相同,说明缺失的数字在后面
start = mid + 1
else:
if (mid > 0 and numbers[mid - 1] == (mid - 1)) or mid == 0:
return mid
end = mid - 1
if start == len(numbers):#这是只有一个元素的情况
return len(numbers) - 1
return -1
# 题目三 数组中数值和下标相等的元素
class Solution3:
def GetNumberSameAsIndex(self,numbers):
if not numbers:
return -1
start, end = 0, len(numbers) - 1
while start<=end:
mid = (start + end) >> 1
if mid == numbers[mid]:
return mid
elif mid < numbers[mid]:
end = mid - 1
else:
start = mid + 1
return -1
lis = [1,2,3,3,3,3,4,5]
lis1 = [0,1,2,4,5,6]
lis2 = [-10,-8,2]
# lis= []
# a = Solution()
# b = a.GetNumberOfK(lis,1)
# print(b)
# a = Solution2()
# print(a.GetMissingNumber(lis1))
a = Solution3()
print(a.GetNumberSameAsIndex(lis2))
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
在排序数组中查找数字.py 二叉搜索树的第k大节点.py 二叉树的深度.py 数组中数字出现的次数.py 和为s的数字.py 翻转字符串.py 队列的最大值.py n个骰子的点数.py 扑克牌中的顺子.py 圆圈中最后剩下的数字.py 股票的最大利润.py 求1+2+…+n.py 不用加减乘除做加法.py 构建乘积数组.py 把字符串转换成整数.py 树中两个节点的最低公共祖先.py
资源推荐
资源详情
资源评论
收起资源包目录
python经典练习及面试题之4.zip (16个子文件)
python经典练习及面试题之4
test58_翻转字符串.py 2KB
test63_股票的最大利润.py 1KB
test67_把字符串转换成整数.py 715B
test66_构建乘积数组.py 628B
test55_二叉树的深度.py 2KB
test62_圆圈中最后剩下的数字.py 944B
test56_数组中数字出现的次数.py 3KB
test60_n个骰子的点数.py 3KB
test65_不用加减乘除做加法.py 570B
test53_在排序数组中查找数字.py 3KB
test64_求1+2+…+n.py 441B
test57_和为s的数字.py 2KB
test68_树中两个节点的最低公共祖先.py 3KB
test59_队列的最大值.py 538B
test61_扑克牌中的顺子.py 1KB
test54_二叉搜索树的第k大节点.py 2KB
共 16 条
- 1
资源评论
梦回阑珊
- 粉丝: 5027
- 资源: 1650
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功