leetcode - Container With Most Water
生活随笔
收集整理的這篇文章主要介紹了
leetcode - Container With Most Water
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
題目鏈接:http://oj.leetcode.com/problems/container-with-most-water/
第一個(gè)解法是用兩個(gè)數(shù)組雙向記錄。方法的時(shí)間復(fù)雜度是O(n+max)。這里的max是height的最大值。當(dāng)時(shí)沒(méi)有想到用雙向遍歷的方法去做。【貌似第一遍leetcode中還從來(lái)沒(méi)有用過(guò)雙向遍歷】
1 class Solution { 2 public: 3 int maxArea(vector<int> &height) { 4 // Start typing your C/C++ solution below 5 // DO NOT write int main() function 6 int max=-1; 7 int * ar; 8 int n = height.size(); 9 ar = new int[n]; 10 vector<int>::iterator ii; 11 int i=0; 12 for (ii= height.begin(); ii!=height.end();ii++, i++){ 13 if (*ii>max) 14 max = *ii; 15 ar[i] = *ii; 16 } 17 int * f, *g; 18 f = new int[max+1]; 19 g = new int [max+1]; 20 for (i=0; i<=max; i++){ 21 f[i]=-1; 22 g[i]=-1; 23 } 24 int j; 25 for (i=0; i<n; i++){ 26 j = ar[i]; 27 while(j>=0 && f[j]==-1){ 28 f[j] = i; 29 j--; 30 } 31 } 32 for (i=n-1; i>=0; i--){ 33 j = ar[i]; 34 while (j>=0 && g[j]==-1){ 35 g[j] = i; 36 j--; 37 } 38 } 39 int area = 0; 40 for (i=0; i<n; i++){ 41 if (g[ar[i]]>i){ 42 int ta = (g[ar[i]]-i)*ar[i]; 43 if (ta>area) 44 area = ta; 45 } 46 } 47 for (i=n-1; i>=0; i--){ 48 if (f[ar[i]]<i){ 49 int ta = (i-f[ar[i]])*ar[i]; 50 if (ta>area) 51 area = ta; 52 } 53 } 54 delete []ar; 55 delete []f; 56 delete []g; 57 return area; 58 } 59 };?雙向遍歷的算法倒是很簡(jiǎn)單:
1 class Solution { 2 public: 3 int maxArea(vector<int> &height) { 4 // Start typing your C/C++ solution below 5 // DO NOT write int main() function 6 int l=0, r = height.size()-1; 7 int area = 0; 8 while (l<r){ 9 int t = (r-l)*min(height[l], height[r]); 10 if (t>area) 11 area = t; 12 if (height[l]<height[r]) 13 l++; 14 else r--; 15 } 16 return area; 17 } 18 };不僅復(fù)雜度降為O(n),代碼量更是大大的少了。
至于證明。你懂的。
?
轉(zhuǎn)載于:https://www.cnblogs.com/zhanghs/archive/2013/03/26/2983624.html
總結(jié)
以上是生活随笔為你收集整理的leetcode - Container With Most Water的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: SQL Server 2000安装指南及
- 下一篇: 从向量的角度理解皮尔逊相关系数