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 ----------


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM