菜的像徐坤
排名
7
文章
192
粉丝
15
评论
16
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

C# 实现二分查找

3289人阅读 2023/1/28 15:36 总访问:959935 评论:0 收藏:0 手机
分类: Csharp

前言

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

这种搜索算法每一次比较都使搜索范围缩小一半。

C#代码

  1.  static void Main(string[] args)
  2.         {
  3.             /*
  4.                   ====折半搜索,也称二分查找算法、二分搜索,是一种在有序数组中查找某一特定元素的搜索算法。=====
  5.                   A 搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束;
  6.                   B 如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较。
  7.                   C 如果在某一步骤数组为空,则代表找不到。这种搜索算法每一次比较都使搜索范围缩小一半。
  8.                   时间复杂度折半搜索每次把搜索区域减少一半
  9.                   "科学计算器中的对数log"是以10为底的对数
  10.                   如果你要算log2(20).....以2为底的对数
  11.                   那你先换底,log2(20)=lg20/lg2
  12.                   计算器中的具体按法:"20","log","/","2","log","="  结果4.3219280948873623478703194294894
  13.                   计算器中的具体按法:"32","log","/","2","log","="  结果5
  14.                */
  15.             int[] y = new int[] { 1234567891011121314151617181920 };
  16.             int loopCount = 0;
  17.             // int rr = BinarySearch(y, 0, y.Length - 1, 13, ref loopCount); //查找数并返回 若有,返回该数,没有则返回-1
  18.             int rr = BinarySearch2(y,8ref loopCount);
  19.             Console.Write("查找次数{0} 索引{1}", loopCount, rr); 
  20.             Console.ReadKey();
  21.         }
  22.         /// <summary>
  23.         /// 二分查找返回索引,不存在则返回-1
  24.         /// </summary>
  25.         /// <param name="arr">数组</param>
  26.         /// <param name="startIndex">开始索引 0</param>
  27.         /// <param name="endIndex">结束索引 </param>
  28.         /// <param name="key">要查找的对象</param>
  29.         /// <param name="count">查找次数</param>
  30.         /// <returns></returns>
  31.         public static int BinarySearch(int[] arr, int startIndex, int endIndex, int key, ref int count)
  32.         {
  33.             //查找次数
  34.             count++;
  35.             //定义下标(折半)
  36.             var index = (startIndex + endIndex) / 2;
  37.             //所有值都找完了,没有符合条件的值
  38.             if (startIndex > endIndex)
  39.                 return -1;
  40.             //如果等于目标值
  41.             if (arr[index] == key) 
  42.                 return index; 
  43.             //如果大于目标值,则证明在另外一个区间内
  44.             else if (arr[index] > key) 
  45.               return  BinarySearch(arr, startIndex, index - 1, key, ref count); 
  46.             //如果小于目标值,则证明在另外一个区间内
  47.             else 
  48.                return BinarySearch(arr, index + 1, endIndex, key, ref count); 
  49.         }
  50.         /// <summary>
  51.         /// 二分查找非递归方法
  52.         /// </summary>
  53.         /// <param name="arr">数组</param>
  54.         /// <param name="key">要查找的对象</param>
  55.         /// <param name="count">查找次数</param>
  56.         /// <returns></returns>
  57.         public static int BinarySearch2(int[] arr,int key,ref int count) 
  58.         {
  59.             //定义开始索引
  60.             int startIndex = 0;
  61.             //定义结束索引
  62.             int endIndex = arr.Length - 1;
  63.             //定义下标(折半)
  64.             var index = 0;
  65.             while (startIndex<= endIndex)
  66.             {
  67.                 count++;
  68.                 index = (startIndex + endIndex) / 2;
  69.                 if (arr[index]> key)
  70.                 {
  71.                     endIndex = index - 1;
  72.                 }
  73.                 else if (arr[index] < key)
  74.                 {
  75.                     startIndex = index + 1;
  76.                 }
  77.                 else
  78.                 {
  79.                    return index;
  80.                 } 
  81.             }
  82.             return -1
  83.         }


评价

Css弹性盒子,flex布局

css弹性盒子由于版本不同浏览器问题造成了一些不同的写法display:flexbox;在google浏览器中如果使用下面的写法就不行displa...

Css图片和文字对齐问题

文字和图片写到一排经常会出现对不齐的问题 这样感觉图片会上来一点没有和文字对齐,如下图 但是如果修改下html结...

GitHub 上传项目

补充简化方法:登录git创建项目--&gt;拉取刚刚创建的项目--&gt;复制需要的代码进去--&gt;上传提交即可先拉取项目在上传代码...

NET Core 使用 EF Code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

Windows平台分布式架构实践 - 负载均衡

原文地址: https://www.cnblogs.com/atree/p/windows_loadbalancer.html 概述  最近.NET的世界开始闹腾了,微软官方终...

Css实现简单矩形对话框

在前端做项目时,我们可能会遇到写对话框的需求,这次做视频会议页面就遇到了,记录下日后有个参照。//网页部分 &lt;divcla...

CAPS.NET 保存base64位格式的图片

publicvoidUpload() { //取出图片对应的base64位字符 stringimgBase=Request[&quot;imgBase&quot;]; //c#里边的base6...

使用OLEDB读取不同版本ExCel的连接字符串设置

使用OleBD读取excel的时候,excel不同的版本,连接字符串的写法也会不一样。///&lt;summary&gt; ///读取excel ///&lt;/su...

vs2017 对 COM 组件的调用返回了错误 HRESULT E_FAIL

vs2017添加引用报错 对 COM 组件的调用返回了错误 HRESULT E_FAIL 1.以管理员身份打开vs2017开发人员命令指示符 2...

分布式服务架构与微服务架构概念的区别与联系

分布式:分散压力。微服务:分散能力。当下理解分布式:不同模块部署在不同服务器上作用:分布式解决网站高并发带来问题集...

分布式-微服务-集群的区别

1.分布式将一个大的系统划分为多个业务模块,业务模块分别部署到不同的机器上,各个业务模块之间通过接口进行数据交互。区...

NPOI操作exCel 2007/2010版本

HSSFWorkbook:是操作Excel2003以前(包括2003)的版本,扩展名是.xlsXSSFWorkbook:是操作Excel2007的版本,扩展名是.xlsx先...

这样学英语三个月超过你过去学三年

本文作者三年间从四级勉强及格到高级口译笔试210,口试232。找工作面试时给其口试的老外考官听了一分钟就说你的英语不用考...

EasyUI弹窗批量修改Combogrid下拉框的值

JS方法//点击弹出批量修改框 UpdateLot:function(){ varrow=$(&quot;#dg&quot;).datagrid(&quot;getChecked&quot;); if(...

js与Controller中分割字符串的方法

js: varstr=OpenRule; varstrs=newArray(); strs=str.split(&quot;,&quot;); for(vari=0;i&lt;strs.length;i++){ $(&q...

如何修改CSS中存在的element.style内联样式

改腾讯地图的时候调整了下样式,发现样式一直存在问题,修改style里面的值,一点用都没有,html中这个值还找不到是在哪里出...