日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

二分查找算法(递归与非递归两种方式)

發(fā)布時間:2025/3/19 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 二分查找算法(递归与非递归两种方式) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

首先說說二分查找法。

二分查找法是對一組有序的數(shù)字中進行查找,傳遞相應的數(shù)據(jù),進行比較查找到與原數(shù)據(jù)相同的數(shù)據(jù),查找到了返回1,失敗返回對應的數(shù)組下標。


采用非遞歸方式完成二分查找法。java代碼如下所示。

[java]?view plain?copy?print?

  • ????/*?

  • ?????*?非遞歸二分查找算法?

  • ?????*?參數(shù):整型數(shù)組,需要比較的數(shù).?

  • ?????*/??

  • ????public?static?int?binarySearch(Integer[]srcArray,int?des){??

  • ????????//第一個位置.??

  • ????????int?low=0;??

  • ????????//最高位置.數(shù)組長度-1,因為下標是從0開始的.??

  • ????????int?high=srcArray.length-1;??

  • ????????//當low"指針"和high不重復的時候.??

  • ????????while(low<=high){??

  • ????????????//中間位置計算,low+?最高位置減去最低位置,右移一位,相當于除2.也可以用(high+low)/2??

  • ????????????int?middle=low+((high-low)>>1);??

  • ????????//與最中間的數(shù)字進行判斷,是否相等,相等的話就返回對應的數(shù)組下標.??

  • ????????if(des==srcArray[middle]){??

  • ????????????return?middle;??

  • ????????//如果小于的話則移動最高層的"指針"??

  • ????????}else?if(des<srcArray[middle]){??

  • ????????????high=middle-1;??

  • ????????//移動最低的"指針"???

  • ????????}else{??

  • ????????????low=middle+1;??

  • ????????????}??

  • ????????}??

  • ????????return-1;??

  • ????????}??

  • ??????

  • }??




  • 采用遞歸方式完成二分查找算法。代碼如下所示。


    [java]?view plain?copy?print?

  • /**?

  • ?*?遞歸方法實現(xiàn)二分查找法.?

  • ?*?@param?Array數(shù)組?

  • ?*?@param?low?數(shù)組第一位置?

  • ?*?@param?high?最高?

  • ?*?@param?key?要查找的值.?

  • ?*?@return?返回值.?

  • ?*/??

  • int?BinSearch(int?Array[],int?low,int?high,int?key)??

  • {??

  • ????if?(low<=high)??

  • ????{??

  • ????????int?mid?=?(low+high)/2;??

  • ????????if(key?==?Array[mid])??

  • ????????????return?mid;??

  • ????????else?if(key<Array[mid])??

  • ????????????//移動low和high??

  • ????????????return?BinSearch(Array,low,mid-1,key);??

  • ????????else?if(key>Array[mid])??

  • ????????????return?BinSearch(Array,mid+1,high,key);??

  • ????}??

  • ????else??

  • ????????return?-1;??

  • }??


  • 遞歸思想會被經(jīng)常用到,更加突出了編程解決問題的高效。


    轉載于:https://blog.51cto.com/8023java/1826305

    總結

    以上是生活随笔為你收集整理的二分查找算法(递归与非递归两种方式)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。