日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

leetcode笔记:Search in Rotated Sorted Array

發布時間:2024/9/21 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 leetcode笔记:Search in Rotated Sorted Array 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一.題目描寫敘述

二.解題技巧

因為這道題出現了旋轉的情況,即比第一個元素小的元素可能出如今數值的后半段或者不出現。

因此。能夠考慮採用變種的二分查找,即在比較中間元素與目標之前,先比較第一個元素與目標的關系。這個時候,會出現三種情況:

1.第一個元素剛好等于目標,返回第一個元素的坐標,函數結束;
2.第一個元素大于目標。那么目標就可能存在被旋轉到數組后面的情況,這個時候,還要比較與數組中間元素的關系,這個時候又會有三種情況:

a.中間元素大于第一個元素,這個時候。目標可能存在于數組的后半段中,遞歸調用函數,尋找目標的坐標; b.中間元素等于目標。返回中間元素的坐標,函數結束; c.中間元素小于第一個元素。這個時候。又能夠分為兩種情況進行:(1).中間元素小于目標元素。那么目標元素可能存在于數組的后半段中,遞歸調用函數,尋找目標的坐標;(2).中間元素大于目標元素。那么目標元素可能存在于數組的前半段中,遞歸調用函數。尋找目標的坐標;

3.第一個元素小于目標,這是也有三種情況須要考慮:

a.中間元素等于目標元素,返回中間元素的坐標,函數結束; b.中間元素大于第一個元素,這個時候,也有兩種情況要考慮:(1).中間元素大于目標,那么目標元素可能存在于數組的前半段中,遞歸調用函數,尋找目標的坐標;(2).中間元素小于目標,那么目標元素可能存在于數組的后半段中,遞歸調用函數,尋找目標的坐標;c.中間元素小于第一個元素,那么目標元素可能存在于數組的前半段中,遞歸調用函數,尋找目標的坐標;

當然,還須要考慮數組的元素個數為0,1, 2,的情況,以及對于遞歸的過程中數組的起始位置坐標以及數組中元素的個數。這些才是這道題的難點所在,我也是調試了非常久才調通代碼的。

三.演示樣例代碼

// 時間復雜度O(log n)。空間復雜度O(1) #include <iostream>using namespace std;class Solution { public:int SearchRotatedSortedArray(int A[], int n, int target){int start = 0;int end = n;int middle = start + (end - start) / 2;while (start != end){if (target == A[middle])return middle;if (A[start] < A[middle]){if ((target < A[middle]) && (A[start] <= target))end = middle;elsestart = middle + 1;}else{if ((target > A[middle]) && (target <= A[end - 1]))start = middle + 1;elseend = middle;}}return -1; // 在數組中找不到目標元素時返回-1} };

四.體會

這答題的難點在于邊界條件和遞歸過程中的數組的第一個元素的指針設置和數組元素個數的設置上面,邊界條件常常是面試題考查的重點。

轉載于:https://www.cnblogs.com/gavanwanggw/p/7159502.html

總結

以上是生活随笔為你收集整理的leetcode笔记:Search in Rotated Sorted Array的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。