亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Leetcode: Find Peak Element

2019-11-14 22:19:22
字體:
來源:轉載
供稿:網友
Leetcode: Find Peak Element
A peak element is an element that is greater than its neighbors.Given an input array where num[i] ≠ num[i+1], find a peak element and return its index.The array may contain multiple peaks, in that case return the index to any one of the peaks is fine.You may imagine that num[-1] = num[n] = -∞.For example, in array [1, 2, 3, 1], 3 is a peak element and your function should return the index number 2.click to show spoilers.Note:Your solution should be in logarithmic complexity.

這道題還是有點麻煩的,要求O(logN)的時間復雜度,想到用二分查找。如果中間元素大于其相鄰后續元素,則中間元素左側(包含該中間元素)必包含一個局部最大值。如果中間元素小于其相鄰后續元素,則中間元素右側必包含一個局部最大值。直到最后左邊沿與右邊沿相遇

這里有幾點要說明:

1. 這里之所以選擇只進行中間元素mid跟其相鄰后續元素mid+1的大小討論,而不涉及前一個元素mid-1,主要是方便。mid=(left+right)/2, 這個除法有一個floor效果在里面,即⌊(left+right)/2⌋。這樣導致left和right不等時,index為mid和mid+1都存在,但是mid-1有可能小于0。這樣每次當mid==0時,mid-1的元素都得特別討論,麻煩。舉個例子,比如left==0, right==1, mid==0, mid-1==-1, mid+1==1,不想討論mid-1這種情況

2. 如果中間元素大于其相鄰后續元素,說明中間元素左側(包含該中間元素)必包含一個局部最大值,這時候中間元素是可能是局部最大點的,所以移動r = mid而不是r = mid-1; 而如果中間元素小于其相鄰后續元素,則中間元素右側必包含一個局部最大值。這時中間元素肯定不會是局部最大點,所以移動l = mid + 1

3. 之所以要用左右邊沿相遇作為找到條件,主要也是不想涉及到mid-1的問題。否則條件是num[mid]>num[mid+1] && num[mid]>num[mid-1]又要分情況mid==0了

4. 如果mid是一個valley, 比如[1, 2, 1, 6, 7], 這時候不知道該往哪邊跳?這時候其實往左往右跳都可以。隨便指定一個方向都可以,要么往左找到2,要么往右找到7(根據定義它也是peak value)。 因為只用找出一個,所以還是O(logN)

 1 public class Solution { 2     public int findPeakElement(int[] num) { 3         int l = 0; 4         int r = num.length - 1; 5         while (l <= r) { 6             if (l == r) return l; 7             int mid = (l + r)/2; 8             if (num[mid] < num[mid+1]) { 9                 l = mid + 1;10             }11             else {12                 r = mid;13             }14         }15         return -1;16     }17 }

(推薦方法)網上另一種老老實實比較mid跟前后元素大小關系的做法:

 1 public int findPeakElement(int[] num) { 2     int n = num.length; 3     if (n <= 1) return 0; 4     // handle the first and last element in num[] 5     if (num[0] > num[1]) return 0; 6     if (num[n - 1] > num[n - 2]) return n - 1; 7     int left = 1, right = n - 2; 8     while (left <= right) { 9         int mid = (left + right) >> 1;10         if (num[mid] > num[mid - 1] && num[mid] > num[mid + 1]) {11             return mid;12         } else if (num[mid] > num[mid + 1]) {13             right = mid - 1;14         } else {15             left = mid + 1;16         }17     }18     return -1;19 }


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲第一色中文字幕| 精品小视频在线| 色综合伊人色综合网| 欧美日韩国产色| 久久精品国产成人| 亚洲精品国产品国语在线| 97超视频免费观看| 97色在线视频| 91日韩在线播放| 久久精品成人欧美大片| 日韩久久精品电影| 色爱精品视频一区| 亚洲国产另类 国产精品国产免费| 亚洲精品视频中文字幕| 日韩国产高清视频在线| 精品福利在线观看| 国产一区二区成人| 国产精品久久久久久五月尺| 国产精品视频在线观看| 国产精品入口免费视频一| 久久亚洲欧美日韩精品专区| 国产福利精品av综合导导航| 日韩精品视频免费在线观看| 欧美成在线视频| 97超级碰在线看视频免费在线看| 国产精品久久999| 精品国产91乱高清在线观看| 亚洲天堂一区二区三区| 国产精品mp4| 亚洲精品美女在线| 亚洲永久免费观看| 日韩美女在线播放| 一区二区三区视频观看| 国产欧美日韩亚洲精品| 91精品在线国产| 川上优av一区二区线观看| 亚洲国产另类久久精品| 97碰碰碰免费色视频| 在线视频中文亚洲| 亚洲在线免费视频| 日韩欧美亚洲国产一区| 亚洲精选在线观看| 69影院欧美专区视频| 久久久久久av| 久久久久成人网| 久久久久久久久91| 国产精品视频一| 色噜噜狠狠色综合网图区| 亚洲第一精品久久忘忧草社区| 成人性教育视频在线观看| 欧美有码在线视频| 亚洲精品美女久久| 国产一区二区成人| 国产精品三级网站| 国产精品日日做人人爱| 裸体女人亚洲精品一区| 日韩高清av一区二区三区| 日韩av综合网| 亚洲欧美另类在线观看| 久久精视频免费在线久久完整在线看| 国产精品一二三在线| 欧美视频国产精品| 欧美影院成年免费版| 亚洲最新av在线| 亚洲一区二区三区在线视频| 在线性视频日韩欧美| 欧美一级片免费在线| 亚洲v日韩v综合v精品v| 欧美极品美女视频网站在线观看免费| 欧美中文字幕在线| 欧美性videos高清精品| 国产精品视频1区| 亚洲综合一区二区不卡| 欧美午夜电影在线| 91精品视频免费看| 韩日欧美一区二区| 国产欧美最新羞羞视频在线观看| 一区二区三区亚洲| 久久国产一区二区三区| 欧美日韩视频免费播放| 欧美激情综合色| 久久久久久国产| 色偷偷91综合久久噜噜| 久久精品久久久久电影| 自拍偷拍免费精品| 一区二区三区无码高清视频| 欧美一级电影久久| 亚洲乱亚洲乱妇无码| 亚洲成人性视频| 亚洲最大福利网站| 成人网页在线免费观看| 午夜精品久久久久久久99黑人| 国模gogo一区二区大胆私拍| 精品久久久久久中文字幕大豆网| 亚洲精品久久视频| 狠狠躁18三区二区一区| 日韩av在线播放资源| 久热国产精品视频| 成人免费看黄网站| 亚洲一区二区日本| 欧美性猛交xxxx富婆弯腰| 欧美大胆a视频| 欧美激情第1页| 欧美成人免费播放| 久久久噜噜噜久噜久久| 国产精品影片在线观看| 北条麻妃久久精品| 欧美大片免费观看在线观看网站推荐| 国产一区二区三区四区福利| 成人网在线免费看| 久久久久在线观看| 国产一区二区三区毛片| 亚洲一区精品电影| 国产日韩欧美电影在线观看| 成人午夜小视频| 亚洲最大福利视频| 亚洲视频在线观看免费| 亚洲成人黄色在线| 欧美丰满少妇xxxxx| 精品亚洲一区二区| 午夜精品一区二区三区视频免费看| 国产精品视频资源| 亚洲欧美日韩一区二区三区在线| 国产精品第七影院| 色综合久久久888| 亚洲精品理论电影| 亚洲人成毛片在线播放| 欧美激情在线播放| 伊人伊成久久人综合网小说| 在线亚洲男人天堂| 亚洲一二在线观看| 久久久久久有精品国产| 日韩中文综合网| 5566成人精品视频免费| 久久久999精品| 人体精品一二三区| 色七七影院综合| 中文字幕成人精品久久不卡| 国产日本欧美一区二区三区| 欧美视频在线观看免费| 久久影院在线观看| 97成人超碰免| 亚洲精品网站在线播放gif| 久久久久久久久亚洲| 91午夜理伦私人影院| 日韩av免费在线| 亚洲精品久久久久中文字幕欢迎你| 欧美极品在线播放| 欧美第一页在线| 97人人爽人人喊人人模波多| 久久亚洲成人精品| 欧美一区二区大胆人体摄影专业网站| 91影院在线免费观看视频| 国产精品视频免费在线| 国产不卡视频在线| 亚洲自拍小视频| 欧美精品video| zzjj国产精品一区二区| 欧美最猛黑人xxxx黑人猛叫黄| 亚洲一区中文字幕在线观看| 国产精品精品久久久| 久久久久久美女| 亚洲色图校园春色| 久久久视频精品|