千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > java二分查找算法的例子

java二分查找算法的例子

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-08-01 10:42:21 1690857741

Java二分查找算法的例子

二分查找算法是一種高效的查找算法,它適用于有序數(shù)組或列表。該算法通過將查找范圍逐漸縮小一半來快速定位目標(biāo)元素。

下面是一個使用Java實(shí)現(xiàn)的二分查找算法的例子:

public class BinarySearch {

public static int binarySearch(int[] arr, int target) {

int left = 0;

int right = arr.length - 1;

while (left <= right) {

int mid = left + (right - left) / 2;

if (arr[mid] == target) {

return mid;

} else if (arr[mid] < target) {

left = mid + 1;

} else {

right = mid - 1;

}

}

return -1; // 如果未找到目標(biāo)元素,則返回-1

}

public static void main(String[] args) {

int[] arr = {1, 3, 5, 7, 9, 11, 13};

int target = 7;

int result = binarySearch(arr, target);

if (result == -1) {

System.out.println("目標(biāo)元素不存在");

} else {

System.out.println("目標(biāo)元素在數(shù)組中的索引為:" + result);

}

}

在上面的例子中,我們定義了一個binarySearch方法,它接受一個有序數(shù)組arr和目標(biāo)元素target作為參數(shù),并返回目標(biāo)元素在數(shù)組中的索引。如果目標(biāo)元素不存在,則返回-1。

算法的核心部分是一個循環(huán),通過不斷調(diào)整查找范圍的左右邊界來逐漸縮小查找范圍,直到找到目標(biāo)元素或查找范圍為空。

在每次循環(huán)中,我們計算中間元素的索引mid,然后與目標(biāo)元素進(jìn)行比較。如果中間元素等于目標(biāo)元素,則返回中間元素的索引。如果中間元素小于目標(biāo)元素,則將左邊界調(diào)整為中間元素的右邊一位。如果中間元素大于目標(biāo)元素,則將右邊界調(diào)整為中間元素的左邊一位。

如果循環(huán)結(jié)束時仍未找到目標(biāo)元素,則返回-1。

main方法中,我們定義了一個有序數(shù)組arr和目標(biāo)元素target,然后調(diào)用binarySearch方法進(jìn)行查找。根據(jù)返回的結(jié)果,我們輸出相應(yīng)的提示信息。

這個例子演示了如何使用Java實(shí)現(xiàn)二分查找算法,并展示了如何在一個有序數(shù)組中查找目標(biāo)元素的索引。

希望這個例子能幫助你理解和應(yīng)用二分查找算法。如果你有任何問題,請隨時提問。

千鋒教育擁有多年IT培訓(xùn)服務(wù)經(jīng)驗(yàn),提供Java培訓(xùn)web前端培訓(xùn)大數(shù)據(jù)培訓(xùn)python培訓(xùn)等課程,采用全程面授高品質(zhì)、高體驗(yàn)培養(yǎng)模式,擁有國內(nèi)一體化教學(xué)管理及學(xué)員服務(wù),想獲取更多IT技術(shù)干貨請登錄千鋒教育IT培訓(xùn)機(jī)構(gòu)官網(wǎng)。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
快速通道
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
亚洲精品欧美视频在线观看 | 一本久久a久久精品vr综合 | 中文字幕一区二区日韩欧美 | 中文字幕精品三级欧美 | 在线看片免费无毒 | 亚洲精品亚洲国产3区 |