编写一个程序:输出在顺序表{1,2,3,4,5,6,7,8,9,10}中采用折半查找法查找关键字9的过程
时间: 2024-05-10 20:15:24 浏览: 105
以下是一个Python程序,演示如何使用折半查找法在顺序表中查找关键字9的过程:
```python
def binary_search(seq, target):
# 定义左右指针
left = 0
right = len(seq) - 1
while left <= right:
# 计算中间位置
mid = (left + right) // 2
if seq[mid] == target:
# 找到目标值,返回位置
return mid
elif seq[mid] < target:
# 目标值在右半部分,移动左指针
left = mid + 1
else:
# 目标值在左半部分,移动右指针
right = mid - 1
# 没有找到目标值,返回 -1
return -1
# 测试程序
seq = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
target = 9
position = binary_search(seq, target)
if position == -1:
print("未找到目标值")
else:
print("目标值在顺序表中的位置为:", position)
```
输出结果为:
```
目标值在顺序表中的位置为: 8
```
这意味着在查找过程中,程序首先将左指针指向第一个元素位置(0),右指针指向最后一个元素位置(9)。然后,程序计算中间位置(4),并将中间值与目标值进行比较。由于中间值是5,而目标值是9,因此目标值在右半部分,程序将左指针移到中间值的右侧(5),并继续进行查找。在下一轮查找中,程序将中间值设置为7(左指针为5,右指针为9的中间值),并将其与目标值进行比较。由于中间值是9,与目标值相等,程序返回该位置。
阅读全文