9.2.2 折半查找(二分查找) 适用条件: 线性表中的记录必须按关键码有序; 必须采用顺序存储。 基本思想:在有序表中,取中间记录作为比较对象 ,若给定值与中间记录的关键码相等,则查找成功; 若给定值小于中间记录的关键码,则在中间记录的左 半区继续查找;若给定值大于中间记录的关键码,则 在中间记录的右半区继续查找。不断重复上述过程, 直到查找成功,或所查找的区域无记录,查找失败。例:查找值为14的记录的过程: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 7 14 18 21 23 29 31 35 38 42 46 49 52 low=1 high=13 mid=7 high=6 mid=3 high=2 mid=1 1431 147 low=2 mid=2 14=14例:查找值为22的记录的过程: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 7 14 18 21 23 29 31 35 38 42 46 49 52 low=1 high=13 mid=7 high=6 mid=3 high=4 mid=5 3122 1822 low=4 mi