Java二分查找算法實現(xiàn)代碼實例
這篇文章主要介紹了Java二分查找算法實現(xiàn)代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下
二分查找:
兩種方式: 非遞歸方式和遞歸方式
主要思路: 對于已排序的數(shù)組(先假定是從小到大排序), 先定義兩個"指針", 一個"指向"首元素low, 一個"指向"末尾元素high. 然后, 開始折半比較, 即讓要查找的數(shù)與數(shù)組中間的元素(索引為 low+high/2)比較. 若要查找的數(shù)比中間數(shù)小, 說明要查找的數(shù)在數(shù)組左側(cè)(注意前提是數(shù)組從小到大排序), 否則說明該數(shù)在數(shù)組的右側(cè). 如果low最后還比high大,倆"指針"交叉了, 說明沒有找到該數(shù), 即數(shù)組不存在該數(shù).
注意事項: 排序規(guī)則與數(shù)組的排序順序有關(guān), 即從大到小排序和從小到大排序是不一樣的!!!
代碼如下
class BinarySearch {
// 二分查找非遞歸方式
// arr 給定已排序數(shù)組
// num 要查找的數(shù)
public static int search(int[] arr, int num) {
int low = 0;
int high = arr.length - 1;
int mid = 0;
while (low <= high) {
mid = (low + high) / 2;
if (num < arr[mid]) {
high = mid - 1;
}
if (num > arr[mid]) {
low = mid + 1;
}
if (num == arr[mid]) {
return mid;
}
}
return -1; // 沒找到
}
// 二分查找遞歸方式
// arr 給定已排序數(shù)組
// num 要查找的數(shù)
// low 初始左側(cè)指針 指向第一個元素
// high 初始末尾指針 指向最后一個元素
public static int binarySearch(int[] arr, int num, int low, int high) {
int mid = (low + high) / 2;
// 遞歸結(jié)束條件
if (low > high) {
return -1;
}
if (num < arr[mid]) {
return binarySearch(arr, num, low, mid - 1);
} else if (num == arr[mid]) {
return mid;
} else {
return binarySearch(arr, num, mid + 1, high);
}
}
public static void main(String[] args) {
// 給定數(shù)組 從小到大排序.
int[] arr = {2, 3, 5, 7, 8, 9, 11, 12, 15};
// int[] arr = {15, 12, 11, 9, 8, 7, 5, 3, 2};
int m = 3;
// int index = search(arr, m);
int index = binarySearch(arr, m, 0, arr.length - 1);
System.out.println(index);
}
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java操作mongodb增刪改查的基本操作實戰(zhàn)指南
MongoDB是一個基于分布式文件存儲的數(shù)據(jù)庫,由c++語言編寫,旨在為WEB應(yīng)用提供可擴展的高性能數(shù)據(jù)存儲解決方案,下面這篇文章主要給大家介紹了關(guān)于Java操作mongodb增刪改查的基本操作實戰(zhàn)指南,需要的朋友可以參考下2023-05-05
java實現(xiàn)往hive 的map類型字段寫數(shù)據(jù)
這篇文章主要介紹了java實現(xiàn)往hive 的map類型字段寫數(shù)據(jù)操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
@Async導(dǎo)致controller?404及失效原因解決分析
這篇文章主要為大家介紹了@Async導(dǎo)致controller?404失效問題解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
springboot3.0整合mybatis-flex實現(xiàn)逆向工程的示例代碼
逆向工程先創(chuàng)建數(shù)據(jù)庫表,由框架負責根據(jù)數(shù)據(jù)庫表,自動生成mybatis所要執(zhí)行的代碼,本文就來介紹一下springboot mybatis-flex逆向工程,感興趣的可以了解一下2024-06-06
SpringBoot定時調(diào)度之Timer與Quartz詳解
Java?中常用的定時調(diào)度框架有以下幾種:Timer、ScheduledExecutorService、Spring?Task和Quartz,本文主要來和大家講講他們的具體使用,需要的可以參考一下2023-06-06

