• 二分查找算法(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.
  • 相关阅读:
    JavaScript函数
    JavaScript数组知识点
    面向对象之继承及属性查找顺序
    面向对象二
    面向对象
    正则表达式补充
    垃圾回收机制、标记删除及分代回收
    hashlib、hmac、subprocess、configparser模块
    模块、起别名、from导入
    递归、匿名函数、内置函数
  • 原文地址:https://www.cnblogs.com/student-note/p/6782205.html
Copyright © 2020-2023  润新知