遞迴(5) 二分查詢的遞迴解法

2021-10-24 01:34:35 字數 609 閱讀 5258

分析:

全範圍內二分查詢 等價於三個子問題:

左邊找(遞迴)

中間找右邊找(遞迴)

注意:左邊找和右邊找只選其一。

**實現:

public

class

_15二分查詢的遞迴解法

; system.out.

println

(binarysearch

(arr,0,

4,4)

);}//arr:傳入的陣列

//low、high:陣列的最低和最高下標

//key:待查詢的元素

private

static int binarysearch

(int[

]arr,int low,int high,int key)

int mid = low+

((high-low)

>>1)

; int midval = arr[mid];if

(midval < key)

else

if(midval>key)

else

}}

執行結果:

二分查詢(遞迴 非遞迴)

二分查詢是一種查詢效率非常高的查詢演算法。又稱折半查詢。起初在資料結構中學習遞迴時實現二分查詢,實際上不用遞迴也可以實現,畢竟遞迴是需要開闢額外的空間的來輔助查詢。本文就介紹兩種方法 其缺點是要求待查表為有序表,且插入刪除困難。因此,折半查詢方法適用於不經常變動而查詢頻繁的有序列表。使用條件 查詢序...

二分查詢(遞迴)

二分查詢 problem description 給出含有n個數的公升序序列,保證序列中的數兩兩不相等,這n個數編號從1 到n。然後給出q次詢問,每次詢問給出乙個數x,若x存在於此序列中,則輸出其編號,否則輸出 1。input 單組輸入。首先輸入乙個整數n 1 n n 3000000 接下的一行包含...

二分查詢(遞迴)

1.問題描述 給定乙個排好序的整型陣列和乙個給定的數字,找到陣列中比給定數字稍微大一點的那個位置,假如沒有找到返回 1 2.思路分析 由題目中我們可以知道陣列是排好序的,那麼我們可以使用二分查詢來找到這個位置,在遞迴的方法中我們需要傳入的引數有陣列的已知陣列,起始位置,結束位置,和給定的目標數字 在...