博客
关于我
【数据结构】查找 上
阅读量:720 次
发布时间:2019-03-21

本文共 2518 字,大约阅读时间需要 8 分钟。

查找与索引技术

查找概론

查找表是由同一类型数据元素或记录构成的集合。键是数据元素中某个数据项的值,而主键则可以唯一标识一个记录。查找是根据给定值在查找表中确定一个关键字等于该值的数据元素或记录。

查找表可以分为静态和动态两种类型。静态查找表仅进行查找操作,而动态查找表在查找过程中可能插入或删除数据元素。

顺序表查找

顺序表查找,又称线性查找,是最基本的查找技术。其工作原理是从表中第一个或最后一个记录开始,逐个比较关键字和给定值,直到找到相等的记录(查找成功)或遍历完整个表(查找失败)。

有哨兵查找

以下是有哨兵顺序查找的实现代码:

int Sequential_Search2(int *a, int n, int key) {    int i;     a[0] = key; // 设置a[0]为关键字值,称为“哨兵”    i = n;       // 循环从尾部开始    while (a[i] != key) {        i--;    }    return i; // 返回0则说明失败}

有序表查找

有序表查找需要前提条件:线性表中的记录必须按关键码有序(通常从小到大)。其核心思想是,在有序表中,先取中间记录作为比较对象,若给定值与中间记录的关键字相等则查找成功;若给定值小于中间记录的关键字,则在左半区继续查找;若大于,则在右半区继续查找。

折半查找

以下是折半查找的实现代码:

int Binary_Search(int *a, int n, int key) {    int low, high, mid;    low = 1;     high = n;    while (low <= high) {        mid = low + (high - low) / 2; // 折半        if (key < a[mid]) {            high = mid - 1; // 调整最高下标到中位下标小一位        } else if (key > a[mid]) {            low = mid + 1; // 调整最低下标到中位下标大一位        } else {            return mid; // 若相等则返回mid位置        }    }    return 0; // 返回0表示失败}

插值查找

插值查找是根据二次插值计算公式进行的 keys - a[low] / (a[high] - a[low])。其优点是可以显著减少查找次数,但前提是表必须严格有序。

以下是插值查找的实现代码:

int Interpolation_Search(int *a, int n, int key) {    int low, high, mid;    low = 1;    high = n;    while (low <= high) {        mid = low + (high - low) * (key - a[low]) / (a[high] - a[low]); // 插值计算        if (key < a[mid]) {            high = mid - 1; // 调整最高下标到插值下标小一位        } else if (key > a[mid]) {            low = mid + 1; // 调整最低下标到插值下标大一位        } else {            return mid; // 相等则返回mid位置        }    }    return 0; // 返回0表示失败}

斐波那契查找

斐波那契查找算法通过维护一个斐波那契序列来确定查找范围。其核心思想是根据当前搜索范围和查找值与中间关键字的关系动态调整查找范围。

以下是斐波那契查找的实现代码:

int Fibonacci_Search(int *a, int n, int key) {    int low, high, mid, i, k = 0;    low = 1;    high = n;    while (n > F[k] - 1) {        k++;    }    for (i = n; i <= F[k] - 1; i++) {        a[i] = a[n];    }    while (low <= high) {        mid = low + F[k - 1] - 1;        if (key < a[mid]) {            high = mid - 1;            k--;        } else if (key > a[mid]) {            low = mid + 1;            k = k - 2;        } else {            if (mid <= n) {                return mid;            } else {                return n;            }        }    }    return 0;}

线性索引

线性索引是将索引项集合组织为线性结构。索引表的内存布局通常采用稠密索引,即每个关键码对应唯一的索引项。

稠密索引

稠密索引要求在每个记录中都包含其对应的索引项。这样的索引表必须是按关键码有序排列的。

分块索引

分块索引将数据集的记录分成若干块,满足以下两个条件:

  • 列表内无序
  • 列表间有序
  • 分块索引的索引项结构包括以下三个数据项:

  • 最大关键码
  • 记录个数
  • 块首指针
  • 在查询时,首先在分块索引表中定位块,再根据块首指针进入块内部进行顺序查找。

    倒排索引

    倒排索引方法记录号表存储具有相同次关键字的所有记录的 主关键字(或记录号)。这样的索引方法可以快速定位所有具有特定次关键字的记录。

    转载地址:http://yarrz.baihongyu.com/

    你可能感兴趣的文章
    MySQL中使用IN()查询到底走不走索引?
    查看>>
    Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
    查看>>
    MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
    查看>>
    mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
    查看>>
    mysql中出现Unit mysql.service could not be found 的解决方法
    查看>>
    mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
    查看>>
    Mysql中各类锁的机制图文详细解析(全)
    查看>>
    MySQL中地理位置数据扩展geometry的使用心得
    查看>>
    Mysql中存储引擎简介、修改、查询、选择
    查看>>
    Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
    查看>>
    mysql中实现rownum,对结果进行排序
    查看>>
    mysql中对于数据库的基本操作
    查看>>
    Mysql中常用函数的使用示例
    查看>>
    MySql中怎样使用case-when实现判断查询结果返回
    查看>>
    Mysql中怎样使用update更新某列的数据减去指定值
    查看>>
    Mysql中怎样设置指定ip远程访问连接
    查看>>
    mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
    查看>>
    Mysql中文乱码问题完美解决方案
    查看>>
    mysql中的 +号 和 CONCAT(str1,str2,...)
    查看>>
    Mysql中的 IFNULL 函数的详解
    查看>>