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 }

浙公网安备 33010602011771号