本文實(shí)例講述了Java實(shí)現(xiàn)的兩種常見(jiàn)簡(jiǎn)單查找算法。分享給大家供大家參考,具體如下:
前言:
查找是指從一批記錄當(dāng)中找出滿足制定條件的某一記錄的過(guò)程。
在平常的程序的編寫當(dāng)中很多時(shí)候時(shí)用得上的,這里簡(jiǎn)單介紹兩個(gè)查找算法
1. 快速查找:
這個(gè)是相當(dāng)簡(jiǎn)單的,以數(shù)組舉例,就用一個(gè)for循環(huán)去查找數(shù)組中需要查找的數(shù)據(jù)
例子:
1
2
3
4
5
6
7
8
9
10
11
12
|
public static boolean quickSearch( int a[], int x) { boolean f = false ; int length = a.length; int i; for (i = 0 ; i < length - 1 ; i++) { if (x == a[i]) { f = true ; break ; } } return f; } |
2. 二分法(折半)查找:
二分法查找,其要求數(shù)據(jù)序列必須是呈線性結(jié)構(gòu)的,也就是說(shuō)數(shù)據(jù)序列必須是排過(guò)序的才能用二分法。
直接舉例(使用二分法的時(shí)候采用遞歸即可):
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
// 二分法方法一 public static boolean erFen( int a[], int low, int high, int x) { boolean f = false ; if (low <= high) { if (x < a[(low + high) / 2 ]) { f = erFen(a, low, (low + high) / 2 - 1 , x); } else if (x > a[(low + high) / 2 ]) { f = erFen(a, (low + high) / 2 + 1 , high, x); } else if (x == a[(low + high) / 2 ]) { f = true ; } } return f; } // 二分法方法二 public static boolean erFen2( int a[], int x) { boolean f = false ; int length = a.length; int low = 0 ; int high = length - 1 ; int mid; while (low <= high) { mid = a[(low + high) / 2 ]; if (mid < x) low = (low + high) / 2 + 1 ; else if (mid > x) high = (low + high) / 2 - 1 ; else if (mid == x) { f = true ; break ; } } return f; } |
希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。
原文鏈接:http://www.cnblogs.com/liangstudyhome/p/4571287.html