二分查詢 遞迴

2021-10-04 09:48:17 字數 1105 閱讀 4746

二分查詢對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

elif data_set[mid]

< val:

low = mid +

1else

: high = mid -

1return

n = bin_search(l,11)

print

(n)# 返回結果是: 10

當數列有序且從小到大時:

這個方法查詢無序的結果將都是不存在

list=[

1,2,

3,4]

defbinary_search()

: start =

0 end =

len(

list)-

1 num =

1while start <= end:

mid =

(start+end)//2

# 先找中間值下標

if num ==

list

[mid]

:print

('該值對應的下標是:'

,mid)

return mid

elif num >

list

[mid]

: start = mid +

1elif num <

list

[mid]

: end = mid -

1print

('不存在'

)binary_search(

)

二分查詢(遞迴)

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

二分查詢(遞迴)

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

二分查詢(遞迴)

二分查詢也稱折半查詢 binary search 它是一種效率較高的查詢方法。但是,折半查詢要求線性表必須採用順序儲存結構,而且表中元素按關鍵字有序排列。如果待查序列為空,那麼就返回 1,並退出演算法 這表示查詢不到目標元素。如果待查序列不為空,則將它的中間元素與要查詢的目標元素進行匹配,看它們是否...