BeatificDevin

。。

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

相关术语:

  查找表:(Search Table)是由同一类型的数据元素(或记录)构成的集合。

  关键字:(Key)是数据元素中某个数据项的值,又称为键值,它可以标识一个数据元素。

  主关键字:若某个关键字可以唯一地标识一个记录,则称此关键字为主关键字(Primary Key)。这就意味着,对于不同的记录,其主关键字均不相同。主关键字所在的数据项 成为主关键码。

  次关键字:对于那些可以识别多个数据元素(或记录)的关键字,我们称之为次关键字(Second Key)。

  查找:就是根据给定的某个值,在查找表中确定一个其关键字等于给定值的数据元素或记录。

  静态查找表:只作查找操作的查找表。

  动态查找表:在查找过程中同时插入查找表中不存在的数据元素,或者从查找表中删除已经存在的某个数据元素。

顺序表查找:

  

/*
这里 a 为一个int型数组的名字,也是数组的头指针int a[n]的形参
n为数组a[n]中元素的个数
key 是要查找的关键字
*/
int SequentialSearch(int *a,int n;int key)
{
    int i;
    for(i = 0;i < n;i++)
    {
        if(a[i] == key)
            return i;
    }
    return 0;
}

这里算法复杂度为O(2n),我们可以对它进行优化成:

int SequentialSearch(int *a,int n;int key)
{
    int i;
    a[0] = key;
    i = n;
    while(a[i] != key)
    {
        i--;
    }
    return i;
}

注意:这里我们默认了a[0]存放的不是我们要搜索数据项,所以,可以把它设置成 " 哨兵 " 。

posted on 2014-12-24 00:22  BeatificDevin  阅读(184)  评论(0编辑  收藏  举报