顺序查找

顺序查找(Sequential Search)算法简单,适用面广(对查找表结构无任何要求),但其查找效率较低,等概率下平均查找长度为(n+1)/2。

在条件允许情况下,顺序查找可以设置一个监视哨,目的在于免去查找过程中每一步都要检测整个表是否查找完毕。严版《数据结构》说这个改进能使查找长度在≥1000时查找所需平均时间几乎减少一半。

顺序查找的C/C++代码实现:

  1. int seq_search(int search_table[], int length, int key)
  2. {
  3.     int i;
  4.     search_table[0] = key;
  5.     for (i = length; key != search_table[i]; --i);
  6.     return i;
  7. }

第4行即为设置监视哨,当然监视哨也可以设在高下标处。

文章若无注明则属原创,转载请以链接形式注明出处。
本文地址:http://www.juliuschen.com/archives/6.html

Leave a Reply