国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

leetcode33 search in rotated sorted array

MkkHou / 1828人閱讀

摘要:這里相比于思路一,更適用于目標節點在中間的情況,而思路一在目標節點分布在數組兩側會效率更高。

題目要求
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.

You may assume no duplicate exists in the array.

翻譯過來就是說:一個由小到大有序排列的數組被分為兩個子數組,這兩個子數組調換前后順序生成一個新數組。在新數組中找到目標值并返回下標

思路一:雙指針

左右同時比較,直至找到目標值或是左右指針相遇

    public int search(int[] nums, int target){ 
        int left = 0;
        int right = nums.length - 1;
        while(left<=right){
            if(nums[left]==target){
                return left;
            }
            if(nums[right] == target){
                return right;
            }
            left++;
            right--;
        }
        return -1;
    }
思路二:二分法查找

思路一并沒有充分利用條件,及這個數組是由兩個有序的子數組合成的。這里我們可以使用二分法的一個變形的算法。先找到中間節點,這個中間節點如果不是在左順序子數組,就一定在右順序子數組,反之亦成立。這樣我們就可以變相的使用二分法將區間范圍逐漸縮小,直至找到目標值。
這里相比于思路一,更適用于目標節點在中間的情況,而思路一在目標節點分布在數組兩側會效率更高。

    public int search(int[] nums, int target){ 
        int left = 0;
        int right = nums.length - 1;
        while(left<=right){
            int mid = (left + right)/2;
            int midNum = nums[mid];
            if(midNum==target){
                return mid;
            }
            if(nums[left]<=midNum){
                if(nums[left]<=target && midNum>target){
                    right = mid - 1;
                }else{
                    left = mid + 1;
                }
            }
            if (midNum <= nums[right]){
                if (target > midNum && target <= nums[right])
                    left = mid + 1;
                 else
                    right = mid - 1;
            }
        }
        return -1;
    }


想要了解更多開發技術,面試教程以及互聯網公司內推,歡迎關注我的微信公眾號!將會不定期的發放福利哦~

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/67054.html

相關文章

  • leetcode 33 Search in Rotated Sorted Array

    摘要:如正常的升序排列應該是,,,,,,旋轉過后可能就是,,,,,,。想法因為這是一個經過旋轉的升序數組,我們可以將其看作兩個升序的序列,,,和,,。如果在前一個序列,則從前面進行查找。如果在后面一個序列,則從最后一個元素開始查找。 題目詳情 Suppose an array sorted in ascending order is rotated at some pivot unknown...

    diabloneo 評論0 收藏0
  • leetcode-33-Search in Rotated Sorted Array

    摘要:由于不是一直升序,所以需要多些條件進行范圍的限定。注意邊界值的確定,有邊界值相等,列表只有一個值,這些情況。注意的使用應用排序,快速確定某個值的位置 題目闡釋: 給定一組升序數組,取某個點之后將數組截斷交換前后兩個數組順序, 給定一個值,求這個值的index 重點:二分法,確定target在哪個列表中,之后不斷二分法進行位置確認。 由于不是一直升序,所以需要多些條件進行范圍的限定...

    SKYZACK 評論0 收藏0
  • [Leetcode] Search in Rotated Sorted Array 搜索旋轉有序數組

    摘要:如果左邊的點比右邊的大,說明這兩個點之間有一個旋轉點,導致了不再有序。因為只有一個旋轉點,所以一分為二后,肯定有一半是有序的。 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...

    thursday 評論0 收藏0
  • [LintCode/LeetCode] Search in Rotated Sorted Arra

    摘要:找中點若起點小于中點,說明左半段沒有旋轉,否則說明右半段沒有旋轉。在左右半段分別進行二分法的操作。只判斷有無,就容易了。還是用二分法優化 Search in Rotated Sorted Array Problem Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 ...

    U2FsdGVkX1x 評論0 收藏0
  • leetcode 81 Search in Rotated Sorted Array II

    摘要:題目要求相比于,中添加了數組中可能存在重復值的條件。這是我們可以將情況分為以下幾種。因為如果而且,則左側或右側的子數組至少有一個為順序的數組,這違背題目要求。所喲一定是同理,如果,那么。 題目要求 Suppose an array sorted in ascending order is rotated at some pivot unknown to you beforehand. ...

    Cheriselalala 評論0 收藏0

發表評論

0條評論

MkkHou

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<