首页 > 其他 > 详细

动态规划

时间:2018-01-23 13:58:43      阅读:222      评论:0      收藏:0      [点我收藏+]

技术分享图片

hdu1506 Largest Rectangle in a Histogram

对于每一个高度h[i],搜索它能到达的最左,和最右,最大面积Smax = Max{ i | 面积Si = (最右 - 最左 + 1) *h[i] }

这样的时间复杂度为O(n^2),必超时

举例 2,3,4,5

要判断2能到达最右的位置,不需要循环比较,只需要知道3能到达的最右是哪里,因为若3能到达的位置,2必然也能到达

技术分享图片
 1 #include<cstdio>
 2 #include<iostream>
 3 using namespace std;
 4 
 5 int main()
 6 {
 7     int n;
 8     while(scanf("%d", &n) && n)
 9     {
10         long long h[100007];
11         long long l[100007];
12         long long r[100007];
13         for(int i=1;i<=n;i++)
14         {
15             scanf("%lld", &h[i]);
16             l[i] = r[i] = i;
17         }
18         h[0] = h[n+1] = -1;
19         for(int i=1;i<=n;i++)
20         {
21             while(h[i] <= h[l[i]-1]) {
22                 l[i] = l[l[i]-1];
23             }
24         }
25         for(int i=n;i>=1;i--)
26         {
27             while(h[i] <= h[r[i]+1]) {
28                 r[i] = r[r[i]+1];
29             }
30         }
31         long long ans = 0;
32         for(int i=1;i<=n;i++)
33         {
34             ans = ans > (r[i]-l[i]+1)*h[i] ? ans : (r[i]-l[i]+1)*h[i];
35         }
36         printf("%lld\n",ans);
37     }
38 }
View Code

 

动态规划

原文:https://www.cnblogs.com/liwenchi/p/8335133.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!