找數字 遞迴,二分查詢

2022-07-03 15:48:17 字數 452 閱讀 4766

題目:在一從大到小排序的序列中用遞迴找乙個數在不在這序列,在輸出yes,不在輸出no

這題用了二分查詢的遞迴實現

思路:把陣列和變數都變成全域性變數方便遞迴函式修改

然後如果不可能就跳出迴圈

如果可能但現在沒找到就縮小範圍進入下乙個遞迴過程

如果找到了就輸出

**:

#includeusing

namespace

std;

int a[1000

];int

n,key;

int finder(int l,int r)//

左和右

int mid=(l+r)/2

;

if(a[mid]else

if(a[mid]>key)

else

}int

main()

二分查詢(遞迴)

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

二分查詢(遞迴)

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

二分查詢 遞迴

二分查詢對1 100亂序數字查詢 l list range 1 101 defbin search data set,val low 0 high len data set 1 while low high mid low high 2 if data set mid val return mid ...