力扣33 搜尋旋轉排序陣列

2021-10-08 06:32:54 字數 469 閱讀 1624

假設公升序排序的陣列在某個節點上進行了旋轉,比如說[1,2,3,4,5,6]旋轉之後變成了[4,5,6,1,2,3]

搜尋乙個給定的目標值,如果陣列中存在這個目標值,則返回該值的下標,否則的話返回-1;

思路:題目要求使用o(logn)的時間複雜度,因此主要考慮二分法

二分法的主要模板如下所示:

int left=

0,right=nums.length-1;

while

(left<=right)

//因此根據二分法的模板,來思考本題;

public

intfindtarget

(int

nums,

int target)

//如果前半段有序的話

else

}return-1

;}}

力扣c語言實現 33 搜尋旋轉排序陣列

整數陣列 nums 按公升序排列,陣列中的值 互不相同 在傳遞給函式之前,nums 在預先未知的某個下標 k 0 k nums.length 上進行了 旋轉,使陣列變為 nums k nums k 1 nums n 1 nums 0 nums 1 nums k 1 下標 從 0 開始 計數 例如,0...

33 搜尋旋轉排序陣列

假設按照公升序排序的陣列在預先未知的某個點上進行了旋轉。例如,陣列 0,1,2,4,5,6,7 可能變為 4,5,6,7,0,1,2 搜尋乙個給定的目標值,如果陣列中存在這個目標值,則返回它的索引,否則返回 1。你可以假設陣列中不存在重複的元素。你的演算法時間複雜度必須是 o log n 級別。示例...

33 搜尋旋轉排序陣列

假設按照公升序排序的陣列在預先未知的某個點上進行了旋轉。例如,陣列 0,1,2,4,5,6,7 可能變為 4,5,6,7,0,1,2 搜尋乙個給定的目標值,如果陣列中存在這個目標值,則返回它的索引,否則返回 1。你可以假設陣列中不存在重複的元素。你的演算法時間複雜度必須是o log n 級別。輸入 ...