黑马程序员-折半法判断数组元素位置

---------------------- Windows Phone 7手机开发.Net培训、期待与您交流! ----------------------


  private void button1_Click(object sender, EventArgs e)
        {
            
            int[] a = { 1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17};//数组
            int key = int.Parse(txtKey.Text);//找到要搜索的那个KEY


            int location = BindarySearch(a, key);//位置
            s.Text += "位置"+location;
            if (location == -1)
            {
                s.Text += "未发现";
            }
            


        }
        public int BindarySearch(int[] array, int key)//返回所在的位置
        {
            int low = 0, high = array.Length - 1;
            int middle;
            while (low <= high)
            {
                middle = (low + high) / 2;
               
                if (array[middle] == key)
                {
                    return middle;
                }
                else if (array[middle] > key)
                {
                    high = middle - 1;
                }
                else
                {
                    low = middle + 1;
                }


                s.Text += middle.ToString()+" ";
            }
            return -1;
        }
     

折半法判断,更加适用于排序号的数组,查找元素的位置

线性查找则更适合于乱序数组。

程序员不能瞎大方!!!!严谨性,不能随意的扩大折半数组的长度

if (array[middle] == key)
                {
                    return middle;
                }
                else if (array[middle] > key)
                {
                    high = middle - 1;(本想+1又何妨)
                }
                else
                {
                    low = middle + 1;(-1更广范围的判断)
                }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值