




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第關(guān)于二分法查找Java的實(shí)現(xiàn)及解析
publicstaticintbinarySearch(Integer[]srcArray,intdes){
//定義初始最小、最大索引
intstart=0;
intend=srcArray.length-1;
//確保不會(huì)出現(xiàn)重復(fù)查找,越界
while(start=end){
//計(jì)算出中間索引值
intmiddle=(end+start)//防止溢出
if(des==srcArray[middle]){
returnmiddle;
//判斷下限
}elseif(dessrcArray[middle]){
end=middle-1;
//判斷上限
}else{
start=middle+1;
//若沒有,則返回-1
return-1;
循環(huán)實(shí)現(xiàn)代碼(非遞歸)
packagesearch;
importjava.util.ArrayList;
importjava.util.Arrays;
importjava.util.List;
*@Author:sshdg
*@Date:2025/9/219:22
publicclassBinarySearch2{
publicstaticvoidmain(String[]args){
int[]array={1,1,1,1,1,2,3,4,5,6,7};
System.out.println(BinarySearch2.binarySearch(array,7));
publicstaticListIntegerbinarySearch(int[]array,intkey){
ListIntegerresultList=newArrayList();
intstart=0;
intend=array.length-1;
while(start=end){
intmid=(start+end)/2;
intmidValue=array[mid];
if(keymidValue){
//key比中間值大。向右找
start=mid+1;
}elseif(keymidValue){
//key比中間值小。向左找
end=mid-1;
}else{
//否則就找到了
//先向左找有沒有相同值
inttemp=mid-1;
while(temp=startarray[temp]==key){
resultList.add(temp);
temp-=1;
//將一開始找到的加入結(jié)果集
resultList.add(mid);
//再向右找找有沒有相同值
temp=mid+1;
while(temp=endarray[temp]==key){
resultList.add(temp);
temp+=1;
break;
returnresultList;
二分法查找(遞歸、循環(huán))
publicclassBinarySearch{
*@authorJadeXu
*@//TODO:2025/12/7二分查找
*思路:
*1、獲取數(shù)組的中間值,先獲取下標(biāo),方便多次查找
*奇數(shù)位的數(shù)組直接獲取中間位,偶數(shù)位的數(shù)組獲取中間的第一位或第二位都可,一般獲取第一位(因?yàn)榕c奇數(shù)位獲取中間值的方法一樣)
*2、獲取查找的區(qū)間范圍,start:區(qū)間開始的下標(biāo),end:區(qū)間結(jié)束的下標(biāo)
*3、判斷查找的數(shù)和中間位的數(shù)是否相同
*相同時(shí),直接返回需要的數(shù)據(jù),跳出方法
*大于時(shí),即數(shù)可能在中間值右邊的區(qū)間內(nèi),此時(shí)start=mid+1,即mid往后移一位,就得到了中間值右邊區(qū)間的開始下標(biāo)
*小于時(shí),即數(shù)可能在中間值左邊的區(qū)間內(nèi),此時(shí)end=mid-1,即mid往前移一位,就得到了中間值左邊區(qū)間的結(jié)束下標(biāo)
*當(dāng)一個(gè)區(qū)間里,開始下標(biāo)小于等于結(jié)束下標(biāo)時(shí),該區(qū)間才是有效區(qū)間,才能繼續(xù)查找。否則無效,返回找不到,跳出方法
//循環(huán)
*@paramarr已經(jīng)升序好的int[]
*@paramnum需要查找的數(shù)字
*@return找到則返回下標(biāo),沒找到則返回-1
privatestaticintbinarySearchByCycle(int[]arr,intnum){
intstart=0;
intend=arr.length-1;
while(start=end){
intmid=(start+end)/2;
if(num==arr[mid]){
returnmid;
}elseif(numarr[mid]){
start=mid+1;
}else{
end=mid-1;
return-1;
//遞歸
*@paramarr已經(jīng)升序好的int[]
*@paramnum需要查找的數(shù)字
*@paramstart區(qū)間開始下標(biāo)
*@paramend區(qū)間結(jié)束下標(biāo)
*@return找到則返回下標(biāo),沒找到則返回-1
privatestaticintbinarySearchByRecursion(int[]arr,intnum,intstart,intend){
intmid=(start+end)/2;
if(num==arr[mid]){
returnmid;
}elseif(numarr[mid]){
start=mid+1;
}else{
end=mid-1;
if(start
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 單位房屋租賃合同書
- 2025西安美術(shù)學(xué)院輔導(dǎo)員考試試題及答案
- 2025遼寧理工學(xué)院輔導(dǎo)員考試試題及答案
- 2025鹽城工業(yè)職業(yè)技術(shù)學(xué)院輔導(dǎo)員考試試題及答案
- 2025赤峰學(xué)院輔導(dǎo)員考試試題及答案
- 2025福建水利電力職業(yè)技術(shù)學(xué)院輔導(dǎo)員考試試題及答案
- 江蘇蘇州凌曄進(jìn)出口有限公司招聘筆試題庫2025
- 內(nèi)蒙古賽一建建筑工程有限公司招聘筆試題庫2025
- 四川綿陽愛聯(lián)科技股份有限公司招聘筆試題庫2025
- 社區(qū)矯正集中教育
- 江蘇省南通市海安市2024-2025學(xué)年高二下學(xué)期4月期中生物試題(原卷版+解析版)
- 中國鐵路西安局招聘高校畢業(yè)生考試真題2024
- 2025年開展安全生產(chǎn)月活動(dòng)方案 合計(jì)3份
- 2023北京初三一模數(shù)學(xué)試題匯編:代數(shù)綜合(第26題)
- 畢業(yè)設(shè)計(jì)產(chǎn)品包裝設(shè)計(jì)
- 安徽卷-2025屆高考化學(xué)全真模擬卷
- 河北省石家莊市2025屆普通高中高三教學(xué)質(zhì)量檢測(cè)(三)英語試卷及答案
- 2025屆百師聯(lián)盟高三下學(xué)期二輪復(fù)習(xí)聯(lián)考(三)政治試題(含答案)
- 山東財(cái)經(jīng)綜招試題及答案
- 2024年云南省文山州第二人民醫(yī)院選調(diào)工作人員考試真題
- 《埃菲爾鐵塔》課件
評(píng)論
0/150
提交評(píng)論