当前位置:
首页 > Python基础教程 >
-
C#教程之C# -- 二分法查找
二分法查找:适用于已经排序好的数组
1.二分法查找(入门案例)
1 static void Main(string[] args) 2 { 3 int[] myNums = { 1, 13, 22, 34, 56, 143, 167, 211, 266, 363, 466, 572, 595, 645, 688, 689, 702, 779, 888,899,922 }; 4 5 Console.WriteLine("我的数组是:"); 6 for (int i = 0; i < myNums.Length; i++) 7 { 8 Console.Write("{0} ",myNums[i]); 9 } 10 Console.WriteLine(); 11 12 //使用二分法从数组查找指定值 13 //取得查找值在数组中的索引位置 14 int QueryValueIndex = QueryFromTwoParts(688, myNums, 0, myNums.Length - 1); 15 Console.WriteLine("--------------------------------------------------------"); 16 Console.WriteLine("查找值688在数组中的索引位置是:{0}",QueryValueIndex); 17 Console.WriteLine("数组myNums索引位置{0}处的值是:{1}",QueryValueIndex,myNums[QueryValueIndex]); 18 19 Console.ReadKey(); 20 } 21 22 23 //该方法返回的是查找值在数组中的索引位置 24 private static int QueryFromTwoParts(int QueryValue, int[] nums, int leftIndex, int rightIndex) 25 { 26 //计算数组中间值的在数组中的索引位置 27 int midValueIndex = (leftIndex + rightIndex + 1) / 2; 28 29 //取得数组中间索引位置处的值 30 int midValue = nums[midValueIndex]; 31 32 //比较中间值与查找值的大小,确定下一步该怎样继续查询 33 if (QueryValue ==midValue) 34 { 35 return midValueIndex; 36 } 37 else if (QueryValue<midValue) 38 { 39 return QueryFromTwoParts(QueryValue, nums, leftIndex, midValueIndex); 40 } 41 else 42 { 43 return QueryFromTwoParts(QueryValue, nums, midValueIndex, rightIndex); 44 } 45 46 }
2.代码运行结果:
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式