C#二分查找算法设计实现

Wesley13
• 阅读 559

C#二分查找算法设计实现

1.介绍

二分查找也称折半查找(Binary Search),它是一种效率较高的查找方法。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。(记住了前提要求是顺序存储结构,而且要有序排序,所以说对于一个无序的是没法用二分查找的)

2.查找算法过程

举例就一个int类型数组为例 比如int[] intArray;

假设数组中元素是按升序排列,将数组中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功;否则利用中间位置记录将表分成前、后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表。重复以上过程,直到找到满足条件的记录,使查找成功,或直到子表不存在为止,此时查找不成功。

复杂度:O(lg n),n为要查找的元素个数。

3.算法要求

  1. 必须采用顺序存储结构。
  2. 必须按关键字大小有序排列。

4.算法实现

这里以C#代码实现  

4.1递归方法

 1         /// <summary>
 2         /// 二分查找递归实现
 3         /// </summary>
 4         /// <param name="arr">数组</param>
 5         /// <param name="low">开始索引 0</param>
 6         /// <param name="high">结束索引 </param>
 7         /// <param name="key">要查找的对象</param>
 8         /// <returns>返回索引</returns>
 9         public static int BinarySearch(int[] arr, int low, int high, int key)
10         {
11             int mid = (low + high) / 2;//中间索引
12             if (low > high)
13                 return -1;
14             else
15             {
16                 if (arr[mid] == key)
17                     return mid;
18                 else if (arr[mid] > key)
19                     return BinarySearch(arr, low, mid - 1, key);
20                 else
21                     return BinarySearch(arr, mid + 1, high, key);
22             }
23         }

4.2While循环实现

 1         /// <summary>
 2         /// 二分查找While循环实现
 3         /// </summary>
 4         /// <param name="nums">数组</param>
 5         /// <param name="low">开始索引</param>
 6         /// <param name="high">结束索引</param>
 7         /// <param name="target">要查找的对象</param>
 8         /// <returns>返回索引</returns>
 9         public static int BinaryWhile(int[] nums, int low, int high, int target)
10         {
11             while (low <= high)
12             {
13                 int middle = (low + high) / 2;
14                 if (target == nums[middle])
15                 {
16                     return middle;
17                 }
18                 else if (target > nums[middle])
19                 {
20                     low = middle + 1;
21                 }
22                 else if (target < nums[middle])
23                 {
24                     high = middle - 1;
25                 }
26             }
27             return -1;
28         }

5.测试代码

 1         static void Main(string[] args)
 2         {
 3             int[] intArray = new int[] { 1,2,3,4,5,6,7,8,9,10};
 4             int result = BinarySearch(intArray,0,intArray.Length-1,5);
 5             Console.WriteLine(result.ToString());
 6             Console.WriteLine("-------------------------------------------");
 7             int resuleWhile = BinaryWhile(intArray,0,intArray.Length-1,5);
 8             Console.WriteLine(resuleWhile.ToString());
 9             Console.Read();
10         }

6.输出结果

C#二分查找算法设计实现

7.源代码工程下载

源码工程项目文件下载

点赞
收藏
评论区
推荐文章
皮卡皮卡皮 皮卡皮卡皮
3年前
javaScript. Dom 基本操作
DOM节点查找jsdocument.getElementById()//通过id查找document.getElementsByTagName()//通过标签名document.getElementsByName()//通过name名查找document.getElementsByClassName("类名")//通过类名获取元素对象documen
22 22
3年前
如何找东西?查找算法之顺序查找和二分查找详解
本文属于系列文章【】1.何为查找?我们平常做很多事情,都会涉及到大量的增删改查操作。比如一个用户管理系统,会涉及用户注册(增)、用户注销(删)、修改用户信息(改)、查找用户(查),其中“删”和“改”要依赖“查”操作。下面重点来介绍一下查找这个重要的操作。现给你一个点名册,让你查找一个学生。我们的做法是:根据这个学生的姓名或者学号,在点名
林末 林末
3年前
折半查找-Python版(二分查找)
介绍二分查找也称折半查找(BinarySearch),它是一种效率较高的查找方法。但是,折半查找要求线性表必须采用顺序存储结构,而且表中元素按关键字有序排列。前提必须待查找的序列有序时间复杂度O(log2n)原理1)确定该期间的中间位置K2)将查找的值t与arrayk比较,若相等,查找成功返回此位置;否则确定新的查找区域,继续二分
好买-葡萄 好买-葡萄
3年前
【数据结构与算法】—— 二分查找
1.二分查找的概念二分查找指的是在排好序的数组中,找到目标元素。如果元素存在则返回元素的下标,不存在则返回1.下面以升序为例进行简单描述2.查找过程:取数组中间元素与查找元素target比较。如果target等于中间元素则直接返回中间元素的下标,如果target小于数组中间元素则在数组左边查找,如果target大于数组中间元素则在右边查找。重复以上步骤。
九路 九路
4年前
7 二分搜索树的原理与Java源码实现
1折半查找法了解二叉查找树之前,先来看看折半查找法,也叫二分查找法在一个有序的整数数组中(假如是从小到大排序的),如果查找某个元素,返回元素的索引。如下:intarrnewint{1,3,4,6,8,9};在arr数组中查找6这个元素,查到返回对应的索引,没有找到就返回1思想很简单:1先找到数组中间元素ta
Wesley13 Wesley13
3年前
java 二分查找算法
二分查找又称折半查找,它是一种效率较高的查找方法。将数列按有序(递增或递减)排列,查找过程中采用跳跃式方式查找,即先以有序数列的中点位置为比较对象,如果要找的元素值小于该中点元素,则将待查序列缩小为左半部分,否则为右半部分。通过一次比较,将查找区间缩小一半。它可以明显减少比较次数,提高查找效率。但是,表中的数据元素必
九路 九路
4年前
二分查找法的递归和非递归的实现
//二分查找法非递归实现,在一个有序的数组中查找e元素的位置,找不到返回1publicstaticintbinarySearch(intdata,inte){intl0;intrdata.length1;while(l<r){
Stella981 Stella981
3年前
Git如何帮你查原因
不久前,一位同事为Git的出错,感到烦恼,查找问题的方式非常原始,对于乐于敲命令行的我来说,这哪是一个程序员的所作所为呢!接下来就来说说,怎么高效的查找Git提交出现代码问题的原因。使用【Bisect命令】,是不是很陌生呢。其还是很强大的,先来说一下原理吧!其基于二分查找算法,大概是这样的:如果你想在有n个元素的序列(有序的)中查找元素x,你挑出第
Wesley13 Wesley13
3年前
Java实现的二分查找算法
二分查找又称折半查找,它是一种效率较高的查找方法。折半查找的算法思想是将数列按有序化(递增或递减)排列,查找过程中采用跳跃式方式查找,即先以有序数列的中点位置为比较对象,如果要找的元素值小于该中点元素,则将待查序列缩小为左半部分,否则为右半部分。通过一次比较,将查找区间缩小一半。折半查找是一种高效的查找方法。它可以明显减少比较次数,提高查找效率。但是,
Stella981 Stella981
3年前
Kafka中改进的二分查找算法
最近有学习些Kafak的源码,想给大家分享下Kafak中改进的二分查找算法。二分查找,是每个程序员都应掌握的基础算法,而Kafka是如何改进二分查找来应用于自己的场景中,这很值得我们了解学习。由于Kafak把二分查找应用于索引查找的场景中,所以本文会先对Kafka的日志结构和索引进行简单的介绍。在Kafak中,消息以日志的形式保存,每个日志其实就是一个文