假設公升序排序的陣列在某個節點上進行了旋轉,比如說[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 級別。輸入 ...