【愚公系列】2021年11月 C#版 数据结构与算法解析(二分查找)

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: 【愚公系列】2021年11月 C#版 数据结构与算法解析(二分查找)

二分查找也称折半查找,它是一种效率较高的查找方法。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。 首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。


示例

public class Program {

   public static void Main(string[] args) {

       int[] array = { 8, 11, 21, 28, 32, 43, 48, 56, 69, 72, 80, 94 };

       Console.WriteLine(BinarySearch(array, 80));

       Console.WriteLine(BinarySearch(array, 66, 0, array.Length - 1));

       Console.ReadKey();

   }

   private static int BinarySearch(int[] array, int key) {

       //直接求解

       var min = 0;

       var max = array.Length - 1;

       var mid = 0;

       while (min <= max) {

           mid = (min + max) >> 1;

           if (array[mid] > key) {

               max = mid - 1;

           }

           else if (array[mid] < key) {

               min = mid + 1;

           }

           else if (array[mid] == key) {

               return mid;

           }  

       }

       return -1;

   }

   private static int BinarySearch(int[] array, int key, int low, int high) {

       //递归法

       if (low > high) return -1;

       var mid = (low + high) >> 1;

       if (array[mid] > key)

           return BinarySearch(array, key, low, mid - 1);

       else if (array[mid] < key)

           return BinarySearch(array, key, mid + 1, high);

       else

           return mid;

   }

}

请注意以上递归实现为尾递归:尽量使用尾递归


在最坏的情况下,二分查找需要在最后一次才能查找到目标关键字,假设原问题规模为n,每次折半原问题,设在第k次时问题规模变为1,那么令 2^k=1 ,因为指数和对数互为逆运算,解得 k=log_{2}n ,即二分查找在最坏的情况下的时间复杂度为: O(logn) 。


相关文章
|
18天前
|
编译器 C# 开发者
C# 9.0 新特性解析
C# 9.0 是微软在2020年11月随.NET 5.0发布的重大更新,带来了一系列新特性和改进,如记录类型、初始化器增强、顶级语句、模式匹配增强、目标类型的新表达式、属性模式和空值处理操作符等,旨在提升开发效率和代码可读性。本文将详细介绍这些新特性,并提供代码示例和常见问题解答。
33 7
C# 9.0 新特性解析
|
16天前
|
C# 开发者
C# 10.0 新特性解析
C# 10.0 在性能、可读性和开发效率方面进行了多项增强。本文介绍了文件范围的命名空间、记录结构体、只读结构体、局部函数的递归优化、改进的模式匹配和 lambda 表达式等新特性,并通过代码示例帮助理解这些特性。
28 2
|
26天前
|
存储 消息中间件 NoSQL
Redis数据结构:List类型全面解析
Redis数据结构——List类型全面解析:存储多个有序的字符串,列表中每个字符串成为元素 Eelement,最多可以存储 2^32-1 个元素。可对列表两端插入(push)和弹出(pop)、获取指定范围的元素列表等,常见命令。 底层数据结构:3.2版本之前,底层采用**压缩链表ZipList**和**双向链表LinkedList**;3.2版本之后,底层数据结构为**快速链表QuickList** 列表是一种比较灵活的数据结构,可以充当栈、队列、阻塞队列,在实际开发中有很多应用场景。
|
12天前
|
算法 C#
C#常见的四种经典查找算法
C#常见的四种经典查找算法
|
12天前
|
算法 C# 索引
C#线性查找算法
C#线性查找算法!
|
1月前
|
存储 算法 C#
C#哈希查找算法
C#哈希查找算法
|
1月前
|
算法 C# 索引
C#二分查找算法
C#二分查找算法
|
26天前
|
存储 NoSQL 关系型数据库
Redis的ZSet底层数据结构,ZSet类型全面解析
Redis的ZSet底层数据结构,ZSet类型全面解析;应用场景、底层结构、常用命令;压缩列表ZipList、跳表SkipList;B+树与跳表对比,MySQL为什么使用B+树;ZSet为什么用跳表,而不是B+树、红黑树、二叉树
|
1月前
|
存储 算法 搜索推荐
数据结构--堆的深度解析
数据结构--堆的深度解析
|
1月前
|
机器学习/深度学习 算法 数据挖掘
使用C# 实现期望最大化算法
使用C# 实现期望最大化算法
47 0

推荐镜像

更多
下一篇
无影云桌面