【脚踢数据结构】查找

这篇具有很好参考价值的文章主要介绍了【脚踢数据结构】查找。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  • (꒪ꇴ꒪ ),Hello我是祐言QAQ
  • 我的博客主页:C/C++语言,Linux基础,ARM开发板,软件配置等领域博主🌍
  • 快上🚘,一起学习,让我们成为一个强大的攻城狮!
  • 送给自己和读者的一句鸡汤🤔:集中起来的意志可以击穿顽石!
  • 作者水平很有限,如果发现错误,可在评论区指正,感谢🙏

        数据结构中的查找是指在一个数据集合(例如数组、列表、树等)中,根据给定的某个值或条件,寻找目标元素或符合条件的元素。查找操作旨在确定特定元素是否存在于数据集合中,并在存在时获取其位置或值。在算法和数据结构领域,查找是一项基础操作,它对于许多应用程序的性能和效率至关重要。不同类型的查找方法适用于不同的数据集合和操作需求,涵盖了顺序查找、二分查找、插值查找、树表查找、哈希表查找等。那么接下来我们就讲讲这些查找的实现吧。

一、顺序查找(线性查找)


1.概念

         顺序查找是一种基本查找方法,它一般为从头开始逐个遍历数据集合,直到找到目标元素或遍历完整个集合。

2.算法

        (1) 从数据集合的起始位置开始,逐个比较元素与目标元素;
        (2)如果找到目标元素,返回其位置(索引);
        (3)如果遍历完整个数据集合仍未找到目标元素,返回查找失败。


3.实现

【脚踢数据结构】查找,脚踢数据结构,java,算法,开发语言,数据结构,链表,linux,c语言

         此程序是一个完整的可执行程序,执行结果如上图所示,接下来的其他代码我将只给查找的核心代码,感兴趣的同学可以尝试自己完成其余的代码使之运行,或自行练习编写代码。

#include <stdio.h>

int linear_search(int arr[], int n, int target) {
    for (int i = 0; i < n; i++) {
        if (arr[i] == target) {
            return i;  // 返回目标元素的索引
        }
    }
    return -1;  // 目标元素未找到
}

// 遍历
void display(int arr[], int n) {
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
}

int main() {
    int data[] = {2, 3, 5, 7, 9, 11};
    int n = sizeof(data) / sizeof(data[0]);
	display(data, 6); 
    int target;
	printf("请输入要查找的元素。\n");
    scanf("%d",&target);
    int result = linear_search(data, n, target);
    if (result != -1) {
        printf("元素 %d 在索引 %d(下标)处找到。\n", target, result);
    } else {
        printf("未找到目标元素。\n");
    }

    return 0;
}

二、二分查找(折半查找)


1.概念

        二分查找适用于有序数据集合,它通过重复将数据集划分为两半并比较目标元素与中间元素的大小,从而快速定位目标元素。

2.算法

        (1)在有序数据集合中,确定左右边界;
        (2)计算中间位置 mid = (left + right) / 2
        (3)比较目标元素与中间元素的大小关系;
        (4)如果目标元素等于中间元素,查找成功;
        (5)如果目标元素小于中间元素,继续在左半部分查找;
        (6)如果目标元素大于中间元素,继续在右半部分查找;
        (7)重复步骤2-3,直到找到目标元素或左边界大于右边界。


3.实现

int binary_search(int arr[], int n, int target) {
    int left = 0, right = n - 1;
    while (left <= right) {
        int mid = left + (right - left) / 2;
        if (arr[mid] == target) {
            return mid;  // 返回目标元素的索引
        } else if (arr[mid] < target) {
            left = mid + 1;
        } else {
            right = mid - 1;
        }
    }
    return -1;  // 目标元素未找到
}

三、 插值查找


1.概念

         插值查找是在有序数据集合中通过插值计算来估计目标元素的位置,从而加快查找速度。

2.算法

        (1)在有序数据集合中,确定左右边界;
        (2)计算插值位置 mid = left + (target - arr[left]) * (right - left) / (arr[right] - arr[left])
        (3)比较目标元素与插值位置处元素的大小关系;
        (4)如果目标元素等于插值位置处元素,查找成功;
        (5)如果目标元素小于插值位置处元素,继续在左半部分查找;
        (6) 如果目标元素大于插值位置处元素,继续在右半部分查找;
        (7)重复步骤2-3,直到找到目标元素或左边界大于右边界。


3.实现


        插值查找的实现与二分查找类似,但计算插值位置时使用了插值公式。

int interpolation_search(int arr[], int n, int target) {
    int left = 0, right = n - 1;
    while (left <= right && target >= arr[left] && target <= arr[right]) {
        int pos = left + ((target - arr[left]) * (right - left)) / (arr[right] - arr[left]);
        if (arr[pos] == target) {
            return pos;  // 返回目标元素的索引
        } else if (arr[pos] < target) {
            left = pos + 1;
        } else {
            right = pos - 1;
        }
    }
    return -1;  // 目标元素未找到
}

四、 树表查找(二叉树查找)


        树表查找方法包括各种基于树结构的查找,其中二叉树查找是最简单的一种。


1.概念

         二叉树查找是基于二叉搜索树的查找方法,利用树结构将元素组织起来以支持高效的查找操作。它是先对待查找的数据进行生成树,确保树的左分支的值小于右分支的值,然后在就行和每个节点的父节点比较大小,查找最适合的范围。 这个算法的查找效率很高,但是如果使用这种查找方法要首先创建树。 

2.算法

        (1)从根节点开始,比较目标元素与当前节点的值;
        (2)如果目标元素等于当前节点的值,查找成功;
        (3)如果目标元素小于当前节点的值,继续在左子树中查找;
        (4)如果目标元素大于当前节点的值,继续在右子树中查找;
        (5)如果到达叶子节点仍未找到目标元素,查找失败。


3.实现

#include <stdio.h>
#include <stdlib.h>

// 定义二叉树结点
struct TreeNode {
    int value;
    struct TreeNode* left;
    struct TreeNode* right;
};

// 二叉树查找函数
struct TreeNode* binary_tree_search(struct TreeNode* root, int target) {
    // 当根节点为空或者根节点的值等于目标值时,返回根节点
    if (root == NULL || root->value == target) {
        return root;
    }

    // 如果目标值小于根节点的值,则在左子树中查找
    if (target < root->value) {
        return binary_tree_search(root->left, target);
    }
    // 如果目标值大于根节点的值,则在右子树中查找
    return binary_tree_search(root->right, target);
}

int main() {
    // 构建二叉搜索树
    struct TreeNode* root = (struct TreeNode*)malloc(sizeof(struct TreeNode));
    root->value = 5;
    root->left = NULL;
    root->right = NULL;

    root->left = (struct TreeNode*)malloc(sizeof(struct TreeNode));
    root->left->value = 3;
    root->left->left = NULL;
    root->left->right = NULL;

    root->right = (struct TreeNode*)malloc(sizeof(struct TreeNode));
    root->right->value = 8;
    root->right->left = NULL;
    root->right->right = NULL;

    // 要查找的目标值
    int target = 3;

    // 调用二叉树查找函数
    struct TreeNode* result_node = binary_tree_search(root, target);
    if (result_node) {
        printf("元素 %d 找到了。\n", target);
    } else {
        printf("未找到目标元素。\n");
    }

    // 释放动态分配的内存
    free(root->left);
    free(root->right);
    free(root);

    return 0;
}

        更多C语言Linux系统ARM板实战数据结构相关文章,关注专栏:

   手撕C语言

            玩转linux

                    脚踢数据结构

                            6818(ARM)开发板实战文章来源地址https://www.toymoban.com/news/detail-665389.html

📢写在最后

  • 今天的分享就到这啦~
  • 觉得博主写的还不错的烦劳 一键三连喔~
  • 🎉感谢关注🎉

到了这里,关于【脚踢数据结构】查找的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【脚踢数据结构】深入理解栈

    (꒪ꇴ꒪ ),Hello我是 祐言QAQ 我的博客主页:C/C++语言,Linux基础,ARM开发板,软件配置等领域博主🌍 快上🚘,一起学习,让我们成为一个强大的攻城狮! 送给自己和读者的一句鸡汤🤔: 集中起来的意志可以击穿顽石! 作者水平很有限,如果发现错误,可在评论区指正,感谢🙏

    2024年02月13日
    浏览(35)
  • 【脚踢数据结构】内核链表

    (꒪ꇴ꒪ ),Hello我是 祐言QAQ 我的博客主页:C/C++语言,Linux基础,ARM开发板,软件配置等领域博主🌍 快上🚘,一起学习,让我们成为一个强大的攻城狮! 送给自己和读者的一句鸡汤🤔: 集中起来的意志可以击穿顽石! 作者水平很有限,如果发现错误,可在评论区指正,感谢🙏

    2024年02月13日
    浏览(28)
  • 【脚踢数据结构】队列(顺序和链式)

    (꒪ꇴ꒪ ),Hello我是 祐言QAQ 我的博客主页:C/C++语言,Linux基础,ARM开发板,软件配置等领域博主🌍 快上🚘,一起学习,让我们成为一个强大的攻城狮! 送给自己和读者的一句鸡汤🤔: 集中起来的意志可以击穿顽石! 作者水平很有限,如果发现错误,可在评论区指正,感谢🙏

    2024年02月12日
    浏览(28)
  • 数据结构算法--1 顺序查找二分查找

    顺序查找时间复杂度为O(n) 我们可以借助Python中的函数enumerate,通过enumerate遍历列表返回其索引和值 也可以通过列表长度依次遍历: 但是二分查找时间复杂度为O(logn):

    2024年02月12日
    浏览(42)
  • 数据结构--》掌握数据结构中的查找算法

            当你需要从大量数据中查找某个元素时,查找算法就变得非常重要。         无论你是初学者还是进阶者,本文将为你提供简单易懂、实用可行的知识点,帮助你更好地掌握查找在数据结构和算法中的重要性,进而提升算法解题的能力。接下来让我们开启数据

    2024年02月08日
    浏览(44)
  • 【数据结构(七)】查找算法

    在 java 中,我们常用的查找有四种:     ① 顺序(线性)查找     ② 二分查找/折半查找     ③ 插值查找     ④ 斐波那契查找 问题:     数组arr[] = {1, 9, 11, -1, 34, 89},使用线性查找方式,找出11所在的位置。 代码实现: 运行结果: 问题:     请

    2024年02月04日
    浏览(35)
  • 数据结构--6.3查找算法(静态、动态)(插值查找)

    静态查找:数据集合稳定,不需要添加,删除元素的查找操作。 动态查找:数据集合在查找的过程中需要同时添加或删除元素的查找操作。 对于静态查找来说,我们不妨可以用线性表结构组织数据,这样可以使用顺序查找算法,如果我们在对进行排序,则可以使用折

    2024年02月09日
    浏览(31)
  • 数据结构与算法:树形查找

    左子树结点值 根结点值 右子树结点值 对二叉排序树进行中序遍历,可以得到一个递增的有序数列 原理: 对于一个给定的二叉排序树,如果要查找一个节点,可以按照以下步骤进行: 从根节点开始比较。 如果要查找的值等于当前节点的值,则找到了目标节点,返回该节点。

    2024年02月06日
    浏览(31)
  • 数据结构与算法之查找: 顺序查找 (Javascript版)

    顺序查找 思路 遍历数组 找到跟目标值相等元素,就返回它的下标 没有找到,返回-1 算法实现 总结 非常低效,算是入门搜索 时间复杂度:O(n) 对于数组结构或链表结构而言,没什么太多可说的

    2024年02月05日
    浏览(39)
  • 数据结构,查找算法(二分,分块,哈希)

    一、查找算法         1、二分查找:(前提条件: 必须有序的序列) 2、分块查找:(块间有序,块内无序)     索引表  +  源数据表     思路:     (1)先在索引表中确定在哪一块中     (2)再遍历这一块进行查找 //索引表 typedef  struct  {     int max; //块中最大值

    2024年02月11日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包