下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第關(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)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 高效團(tuán)隊(duì)建設(shè)與項(xiàng)目管理實(shí)戰(zhàn)指南
- 園林綠化養(yǎng)護(hù)管理實(shí)務(wù)指南
- 工貿(mào)企業(yè)全員安全生產(chǎn)基礎(chǔ)知識(shí)考核(2024年6月)
- 工貿(mào)企業(yè)電氣設(shè)備操作人員安全技能考核(2024年7月)
- XX公司新員工安全生產(chǎn)規(guī)章制度與應(yīng)急預(yù)案考核(2024年3月)
- 工貿(mào)企業(yè)新員工化工裝置操作安全知識(shí)與技能考核(2024年1月)
- 產(chǎn)品質(zhì)量檢測(cè)與改進(jìn)項(xiàng)目報(bào)告
- 雕刻玉石技術(shù)培訓(xùn)課件
- 雕刻時(shí)光培訓(xùn)教程課件
- 制造業(yè)成本核算實(shí)操指南
- 工程維保三方合同
- 地鐵車輛檢修安全培訓(xùn)
- 造血干細(xì)胞移植臨床應(yīng)用和新進(jìn)展課件
- GB/T 10802-2023通用軟質(zhì)聚氨酯泡沫塑料
- 黑布林英語(yǔ)閱讀初一年級(jí)16《柳林風(fēng)聲》譯文和答案
- 杰青優(yōu)青學(xué)術(shù)項(xiàng)目申報(bào)答辯PPT模板
- 宿舍入住申請(qǐng)書
- 深圳中核海得威生物科技有限公司桐城分公司碳13-尿素原料藥項(xiàng)目環(huán)境影響報(bào)告書
- 2023年全國(guó)高考體育單招文化考試數(shù)學(xué)試卷真題及答案
- GB/T 28733-2012固體生物質(zhì)燃料全水分測(cè)定方法
- GB/T 14404-2011剪板機(jī)精度
評(píng)論
0/150
提交評(píng)論