算法背景

有时候,可能会遇到这样的表:整个表中的元素未必有序,但若划分为若干块后,每一块中的所有元素均小于(或大于)其后面块中的所有元素。我们称这种为分块有序。

对于分块有序表的查找

首先,我们需要先建立一个索引表,索引表中为每一块都设置–索引项,每一个索引项都包含两个内容:

  • 该块的起始地址
  • 该块中最大(或最小)的元素

    显然,索引表是按关键字递增或递减次序排列的。如下图所示:
    索引顺序表查找算法(分块查找算法)_索引

查找过程

在前面建立的索引表的基础上,我们查找一个关键字需要两个步骤:

  1. 在索引表中查找,目的是找出关键所属的块的位置。这里如果索引表较大的话,可以采用折半查找。
  2. 进入该块中,使用简单顺序表查找算法进行关键字查找。

算法分析

这种带索引表的分块有序表查找的时间性能取决于两步查找时间之和:如前面所述,第一步可以采用简单顺序查找和折半查找之一进行。第二步只能采用简单顺序查找,但由于子表的长度较原表的长度小。因此,其时间性能介于顺序查找和折半查找之间。