C#中二分法查找的入门(代码介绍)


本文摘自PHP中文网,作者青灯夜游,侵删。

本篇文章通过一个二分法查找的入门案例(代码)来给大家介绍一下C#中的二分法查找是什么?有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

二分法查找:适用于已经排序好的数组

1、二分法查找(入门案例)

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

static void Main(string[] args) {

    int[] myNums = {1,13,22,34,56,143,167,211,266,363,466,572,595,645,688,689,702,779,888,899,922};

 

    Console.WriteLine("我的数组是:");

    for(int i = 0; i < myNums.Length; i++) {

        Console.Write("{0} ", myNums[i]);

    }

    Console.WriteLine();

 

    //使用二分法从数组查找指定值

    //取得查找值在数组中的索引位置

    int QueryValueIndex = QueryFromTwoParts(688, myNums, 0, myNums.Length - 1);

    Console.WriteLine("--------------------------------------------------------");

    Console.WriteLine("查找值688在数组中的索引位置是:{0}", QueryValueIndex);

    Console.WriteLine("数组myNums索引位置{0}处的值是:{1}", QueryValueIndex, myNums[QueryValueIndex]);

 

    Console.ReadKey();

}

 

//该方法返回的是查找值在数组中的索引位置

private static int QueryFromTwoParts(int QueryValue, int[] nums, int leftIndex, int rightIndex) {

    //计算数组中间值的在数组中的索引位置

    int midValueIndex = (leftIndex + rightIndex + 1) / 2;

 

    //取得数组中间索引位置处的值

    int midValue = nums[midValueIndex];

 

    //比较中间值与查找值的大小,确定下一步该怎样继续查询

    if(QueryValue == midValue) {

        return midValueIndex;

    } else if(QueryValue < midValue) {

        return QueryFromTwoParts(QueryValue, nums, leftIndex, midValueIndex);

    } else {

        return QueryFromTwoParts(QueryValue, nums, midValueIndex, rightIndex);

    }

 

}

2、代码运行结果:

以上就是C#中二分法查找的入门(代码介绍)的详细内容!

相关阅读 >>

详解C#winform程序的toolstripbutton自定义背景应用示例源码

关于C#代码convert.tochar(null);出现异常的详解(图)

C#开发 winform如何在选项卡中集成加载多个窗体 实现窗体复用详解(图)

C#中for循环的实例分析

C#学习之面向对象如何调用类以及普通方法、静态方法的使用

C#初步体验fastreport 报表(图)

.net是否真的被国内市场嫌弃?

详细介绍C#时间戳和js时间戳互转方法的代码分享

分享125个基本的C#面试问答

unity 3d 浅谈shader 运行时状态及渲染模式遇到的问题

更多相关阅读请进入《C#》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...