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

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

Leetcode 162. Find Peak Element

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

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; }};
上一篇:錯排和printf輸出%

下一篇:RandomAccessFile

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 景德镇市| 鱼台县| 南京市| 许昌县| 延津县| 长葛市| 株洲县| 龙游县| 武冈市| 波密县| 镇沅| 酒泉市| 灵丘县| 沅江市| 包头市| 梅州市| 香港| 陵水| 澄迈县| 扶余县| 花莲市| 吴江市| 锡林浩特市| 兴海县| 抚州市| 彩票| 嘉善县| 满洲里市| 始兴县| 黔江区| 长葛市| 白城市| 库车县| 玉溪市| 通山县| 凉山| 山阴县| 农安县| 剑河县| 尉犁县| 文昌市|