C# 二分法的解读

注:一定是有序的数组,才可以使用这种算法,如果数组没有排序则先进行排序后再调用此方法。

1、二分法是做什么的呢?

当然是查找数组中的数据了,开个玩笑,哈哈哈。

2、为啥要用这种方式呢?

二分顾名思义,就是将一组数据对半分开(比如左右两部分,下面用左右数组表示),从中间位置开始查找,

如果中间这个值正是咱们要找的值则直接返回这个值(或者索引),如果没有找到,那么去判断中间的这个值和咱们要找的值哪个大,

如果中间值比咱们要找的值大,则将之前分开的数组的左面的数组再进行对半分开,递归直到找到咱们要的那个值才会结束,反之亦然,

但是如果就是没有咱们找的值那么岂不是死循环了嘛,

所以要加判断,如果递归到开始索引大于结束索引,也就是查到最后了还是没有找到匹配的值,则退出。

这种搜索算法每一次比较都使搜索范围缩小一半,这样对于大数据量的数组,极大的提升了查找效率。

        protected void Button1_Click1(object sender, EventArgs e)
        {
            int[] arry = { 8, 15, 19, 23, 26, 31, 40, 65, 91 };
            //测试  要找的数字是15
            int key = 15;
            //查找数并返回 若有,返回该数,没有则返回-1
            int rr = BinarySearch(arry, 0, arry.Length - 1, key);
            Response.Write(rr);
        }
        /// <summary>
        /// 二分法查找指定值
        /// </summary>
        /// <param name="arr">目标数组</param>
        /// <param name="start">开始索引</param>
        /// <param name="end">结束索引</param>
        /// <param name="key">要查找的关键字</param>
        /// <returns></returns>
        public static int BinarySearch(int[] arr, int start, int end, int key)
        {
            int mid = (start + end) / 2;
            if (start > end)
                return -1;//查找不到返回-1
            else
            {
                Console.WriteLine(arr[mid]);//监测查找了哪些数字
                if (arr[mid] == key)
                    return mid;//若查找到,返回该数
                else if (arr[mid] > key)
                {
                    //继续搜寻前半部分,尾索引 为中间数-1
                    return BinarySearch(arr, start, mid - 1, key);
                }
                else
                {
                    //继续搜寻后半部分,头索引 为中间数+1
                    return BinarySearch(arr, mid + 1, end, key);
                }
            }
        }
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值