Java實現(xiàn)的兩種常見簡單查找算法示例【快速查找與二分查找】
本文實例講述了Java實現(xiàn)的兩種常見簡單查找算法。分享給大家供大家參考,具體如下:
前言:
查找是指從一批記錄當中找出滿足制定條件的某一記錄的過程。
在平常的程序的編寫當中很多時候時用得上的,這里簡單介紹兩個查找算法
1. 快速查找:
這個是相當簡單的,以數(shù)組舉例,就用一個for循環(huán)去查找數(shù)組中需要查找的數(shù)據(jù)
例子:
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ù)序列必須是呈線性結構的,也就是說數(shù)據(jù)序列必須是排過序的才能用二分法。
直接舉例(使用二分法的時候采用遞歸即可):
// 二分法方法一 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; }
更多關于java算法相關內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結構與算法教程》、《Java操作DOM節(jié)點技巧總結》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設計有所幫助。
相關文章
從try-with-resources到ThreadLocal,優(yōu)化你的代碼編寫方式
這篇文章主要為大家介紹了從try-with-resources到ThreadLocal,優(yōu)化代碼的編寫方式詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04最新jsonwebtoken-jwt 0.12.3 基本使用小結
這篇文章主要介紹了最新jsonwebtoken-jwt 0.12.3 基本使用小結,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-12-12解決InputStream.available()獲取流大小問題
這篇文章主要介紹了解決InputStream.available()獲取流大小問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06