国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

Leetcode 162. Find Peak Element

2019-11-11 03:24:57
字體:
來源:轉載
供稿:網友

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.

s思路: 1. 這題看著沒難度啊。o(n)一遍,就出結果,出題肯定不是讓我給這個解答。也就意味著有o(lgn). 2. 確實可以用binary search。因為給的這個中間比兩邊大的要求,可以用來判斷binary search的走向。比如: 這里寫圖片描述 上圖,如果mid的位置是下坡,那么肯定有一個peak在mid的左側;如果mid的位置是上坡,那么肯定有一個peak在mid的右側。 3.這題給自己思維的啟發是:如果給的題目,看起來簡單,一下就有結果,通常就意味著出題的人需要更優化的結果,比如:簡單粗暴的做法有o(n^2),那么尋找看是否有o(nlgn)或o(n);簡單粗暴的做法有o(n),那么尋找看是否有o(lgn)!優化的關鍵,在我看來,不是炫技,而是打破潛意識的約束和限制,站在新的角度看問題而已,無所謂好壞!

class Solution {public: int findPeakElement(vector<int>& nums) { // int n=nums.size(); int l=0,r=n-1; while(l<=r){ int m=l+(r-l)/2; if((m==0||nums[m]>nums[m-1])&&(m==n-1||nums[m]>nums[m+1])) return m; if((m==0||nums[m]>nums[m-1])&&(m==n-1||nums[m]<nums[m+1]))//主動加保護 l=m+1; else r=m-1; } return 0; }};
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 仙游县| 太白县| 永福县| 岫岩| 平塘县| 新和县| 焦作市| 治多县| 临漳县| 乌鲁木齐县| 天祝| 安岳县| 枞阳县| 和田县| 宁强县| 巴林左旗| 雅江县| 六枝特区| 河南省| 增城市| 崇仁县| 陇南市| 静乐县| 普洱| 肇源县| 崇左市| 界首市| 琼结县| 鄂尔多斯市| 蓬莱市| 新宁县| 如皋市| 祁东县| 湘潭县| 高青县| 台东市| 如东县| 乳源| 花垣县| 依兰县| 克东县|