zoukankan      html  css  js  c++  java
  • 二分查找算法(C#实现)

    想了解这个算法是因为在最近面试的时候看到了二分查找算法的时候懵比了,所以回来就要恶补一下

      那么什么是二分查找算法呢.

        看名称就知道它是一半一半的找的,有点类似快速排序算法

         举个例子就是:有一个数组int[] array=new int[]{1,3,4,5,6,7};我们要找6这个数

          第一次:中间数是4    6比4大,所以下一次需要找4右边的数

          第二次:中间数是6    刚好

    我们来看一下C#的实现

            public static int fen(int[] array,int low,int high,int key)
            {
                int middle = (low + high) / 2;
                if (low>high)
                {
                    return 1;
                }
                else
                {
                    if (array[middle]==key)
                    {
                        return middle;
                    }
                    else if (array[middle] > key)
                    {
                        return fen(array, low, middle - 1, key);
                    }
                    else
                    {
                        return fen(array, middle+1, high, key);
                    }
                }
            }
            static void Main(string[] args)
            {
                int[] array = new int[] {1,2,3,4,5,6,7,8,9,10 };
                var t=fen(array, 0, array.Length - 1, 9);
                Console.WriteLine(t);
                Console.Read();
            }

    Hold on, everything is possible.
  • 相关阅读:
    12/21
    和寶寶在一起3/10
    11/23
    c#windows应用程序窗体间传值
    用OWC做统计图
    javascript 创建字典
    .NetCom双向数据交换的实现(RecordSet与.Net DataSet的转化)
    JScript 方法 indexOf 方法
    详尽解析window.event对象
    Window.Open详解
  • 原文地址:https://www.cnblogs.com/student-note/p/6782205.html
Copyright © 2011-2022 走看看