c# 折半查找法实现代码

 1 int[] a = new int[20] { 2, 3, 6, 7, 12, 18, 19, 21, 25, 28, 30, 33, 37, 39, 42, 45, 47, 49, 50, 51 };
 2             int x = 18, i;
 3             string j, k;
 4             var d = find(a, x, 0, 19);
 5             if (d == -1)
 6             {
 7                 k = String.Format("未找到{0}", x);
 8             }
 9             else
10             {
11                 for (i = 0; i < 20; i++)
12                 {
13                     if ((i = d) > 0)
14                     {
15                         j = String.Format("{0}是第{1}个数\n", x, i + 1);
16                         break;
17                     }
18                 }
19             }

find方法如下:

1 int find(int[] a, int x, int n, int m)
2         {
3             int i;
4             if (n > m) return -1;
5             i = (n + m) / 2;
6             if (a[i] == x) return i;
7             if (a[i] > x) return find(a, x, n, i - 1);
8             return find(a, x, i + 1, m);
9         }

可以输出j

  显示查找结果

    good luck ----------

转载于:https://www.cnblogs.com/zk-zhou/p/6409432.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值