java 常见的两种简单查找算法(快速+二分)

前言:

    查找是指从一批记录当中找出满足制定条件的某一记录的过程。
     在平常的程序的编写当中很多时候时用得上的,这里简单介绍两个查找算法
1.快速查找:
    这个是相当简单的,以数组举例,就用一个for循环去查找数组中需要查找的数据
     例子:
 1 public static boolean quickSearch(int a[], int x) {
 2         boolean f = false;
 3         int length = a.length;
 4         int i;
 5         for (i = 0; i < length - 1; i++) {
 6             if (x == a[i]) {
 7                 f = true;
 8                 break;
 9             }
10 
11         }
12 
13         return f;
14 
15     }
2.二分法(折半)查找:
          二分法查找,其要求数据序列必须是呈线性结构的,也就是说数据序列必须是排过序的才能用二分法
          直接举例(使用二分法的时候采用递归即可):
  
 1 // 二分法方法一
 2     public static boolean erFen(int a[], int low, int high, int x) {
 3         boolean f = false;
 4 
 5         if (low <= high) {
 6             if (x < a[(low + high) / 2]) {
 7                 f = erFen(a, low, (low + high) / 2 - 1, x);
 8             } else if (x > a[(low + high) / 2]) {
 9                 f = erFen(a, (low + high) / 2 + 1, high, x);
10             } else if (x == a[(low + high) / 2]) {
11                 f = true;
12             }
13 
14         }
15         return f;
16     }
17 
18     // 二分法方法二
19     public static boolean erFen2(int a[], int x) {
20         boolean f = false;
21         int length = a.length;
22         int low = 0;
23         int high = length - 1;
24         int mid;
25         while (low <= high) {
26             mid = a[(low + high) / 2];
27             if (mid < x)
28                 low = (low + high) / 2 + 1;
29             else if (mid > x)
30                 high = (low + high) / 2 - 1;
31             else if (mid == x) {
32                 f = true;
33                 break;
34             }
35         }
36 
37         return f;
38     }
posted @ 2015-06-12 11:38  perfect亮  阅读(1899)  评论(0)    收藏  举报