摘要:如正常的升序排列應(yīng)該是,,,,,,旋轉(zhuǎn)過后可能就是,,,,,,。想法因為這是一個經(jīng)過旋轉(zhuǎn)的升序數(shù)組,我們可以將其看作兩個升序的序列,,,和,,。如果在前一個序列,則從前面進行查找。如果在后面一個序列,則從最后一個元素開始查找。
題目詳情
Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand.想法
(i.e., 0 1 2 4 5 6 7 might become 4 5 6 7 0 1 2).
You are given a target value to search. If found in the array return its index, otherwise return -1.題目的輸入是一個被旋轉(zhuǎn)過的升序排列數(shù)組。(如正常的升序排列應(yīng)該是‘0,1,2,4,5,6,7’;旋轉(zhuǎn)過后可能就是‘4,5,6,7,0,1,2’)。
我們的目標(biāo)就是在這樣一個旋轉(zhuǎn)過的數(shù)組中,找出輸入的目標(biāo)數(shù)字,如果數(shù)字不存在,則返回-1,否則返回數(shù)字在數(shù)組中的位置。
因為這是一個經(jīng)過旋轉(zhuǎn)的升序數(shù)組,我們可以將其看作兩個升序的序列(4,5,6,7和0,1,2)。
接著我們就要判斷我們要找的數(shù)字在哪個序列中。這個時候可以將target元素和數(shù)組的最后一個元素比較。如果target > nums[n-1] 就說明target元素應(yīng)當(dāng)在前一個序列中,反之則在后一個序列中。
如果在前一個序列,則從前面進行查找。如果在后面一個序列,則從最后一個元素開始查找。
解法public int search(int[] nums, int target) { if(nums.length == 0 || nums == null) return -1; int length = nums.length; if(nums[length-1] == target)return length-1; else if(nums[length-1] > target){ for(int i=length-1;i>=0;i--){ if(nums[i] == target) return i; if(nums[i]target) return -1; } } return -1; }
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/71007.html
摘要:這里相比于思路一,更適用于目標(biāo)節(jié)點在中間的情況,而思路一在目標(biāo)節(jié)點分布在數(shù)組兩側(cè)會效率更高。 題目要求 Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 might become 4 5 6 7 0 1 ...
摘要:由于不是一直升序,所以需要多些條件進行范圍的限定。注意邊界值的確定,有邊界值相等,列表只有一個值,這些情況。注意的使用應(yīng)用排序,快速確定某個值的位置 題目闡釋: 給定一組升序數(shù)組,取某個點之后將數(shù)組截斷交換前后兩個數(shù)組順序, 給定一個值,求這個值的index 重點:二分法,確定target在哪個列表中,之后不斷二分法進行位置確認(rèn)。 由于不是一直升序,所以需要多些條件進行范圍的限定...
摘要:如果左邊的點比右邊的大,說明這兩個點之間有一個旋轉(zhuǎn)點,導(dǎo)致了不再有序。因為只有一個旋轉(zhuǎn)點,所以一分為二后,肯定有一半是有序的。 Search in Rotated Sorted Array I Suppose a sorted array is rotated at some pivot unknown to you beforehand.(i.e., 0 1 2 4 5 6 7 mi...
摘要:找中點若起點小于中點,說明左半段沒有旋轉(zhuǎn),否則說明右半段沒有旋轉(zhuǎn)。在左右半段分別進行二分法的操作。只判斷有無,就容易了。還是用二分法優(yōu)化 Search in Rotated Sorted Array Problem Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 ...
摘要:題目要求相比于,中添加了數(shù)組中可能存在重復(fù)值的條件。這是我們可以將情況分為以下幾種。因為如果而且,則左側(cè)或右側(cè)的子數(shù)組至少有一個為順序的數(shù)組,這違背題目要求。所喲一定是同理,如果,那么。 題目要求 Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand. ...
閱讀 2012·2021-11-15 18:09
閱讀 903·2021-09-06 15:13
閱讀 2645·2021-08-23 09:43
閱讀 2026·2019-08-30 15:54
閱讀 2220·2019-08-30 13:56
閱讀 2486·2019-08-26 11:31
閱讀 3081·2019-08-26 10:56
閱讀 705·2019-08-26 10:28