QDUOJ LC的课后辅导 单调递增栈
LC的课后辅导
发布时间: 2015年9月19日 21:42 时间限制: 1000ms 内存限制: 256M
有一天,LC给我们出了一道题,如图:
这个图形从左到右由若干个 宽为1 高不确定 的小矩形构成,求出这个图形所包含的最大矩形面积。
多组测试数据 每组测试数据的第一行为n(0 <= n <= 100), 表示图形有n个小矩形构成 接下来一行输入n个整数h1, h2...hn(0 <= hi <= 1000), 表示每个小矩形的高度 n为0时程序结束
仅输出一行表示面积的最大值
- 7
- 2 1 4 5 1 3 3
- 4
- 1000 1000 1000 1000
- 0
- 8
4000
- 思路:开两个数组分别记录每一个矩形以他为中心所能达到的左右长度,然后面积就是h*(r-l+);这里要注意的是如果该矩形比上一个或后一个矩形要小,则上一个矩形所能达到的区间,该矩形一定可以达到,
- ac代码:
- #include<stdio.h>
- int main()
- { int a[];
- int n,max,i;
- while(scanf("%d",&n)!=EOF)
- {
- if(n==)
- break;
- for(i=;i<=n;i++)
- scanf("%d",&a[i]);
- int l[],r[];
- l[]=;
- r[n]=n;
- int t;
- for(i=;i<=n;i++)
- { t=i;
- while(t>&&a[i]<=a[t-])
- t=l[t-];
- l[i]=t;
- }
- for(i=n-;i>=;i--)
- { t=i;
- while(t<n&&a[i]<=a[t+])
- t=r[t+];
- r[i]=t;
- }
- int max=-;
- for(i=;i<=n;i++)
- { if((r[i]-l[i]+)*a[i]>max)
- max=(r[i]-l[i]+)*a[i];
- }
- printf("%d\n",max);}
- return ;
- }
- 最近在接触单调栈,又用栈实现了一下,这里维护一个单增栈,那么如果要进栈的数不能直接入栈,说明当前栈顶比他大,就说明它可以延伸,一直到可以进栈为止,也就是说通过维护单增栈我们一定可以找到左面第一个比他小的和右面第一个比他小的;
- 还有这里因为矩形的高度可能相同,所以当栈为空时说明可以延伸到头或者尾;
- #include<stdio.h>
- #include<string.h>
- #include<algorithm>
- #include<stack>
- #define N 100010
- using namespace std;
- int a[N],l[N],r[N];
- int main()
- { int n,i;
- while(scanf("%d",&n)!=EOF){
- if(n==)
- break;
- stack<long long >st;
- while(!st.empty())
- st.pop();
- l[]=;
- st.push();
- for(i=;i<=n;i++)
- scanf("%d",&a[i]);
- for(i=;i<=n;i++)
- {
- if(a[st.top()]>=a[i])
- { while(!st.empty()&&a[st.top()]>=a[i])
- {
- st.pop();
- }
- if(st.empty())
- l[i]=;
- else
- l[i]=st.top()+;
- st.push(i);
- }
- else
- { l[i]=i;
- st.push(i);
- }
- }
- while(!st.empty())
- st.pop();
- r[n]=n;
- st.push(n);
- for(i=n;i>=;i--)
- {
- if(a[st.top()]>=a[i])
- { while(!st.empty()&&a[st.top()]>=a[i])
- {
- st.pop();
- }
- if(st.empty())
- r[i]=n;
- else
- r[i]=st.top()-;
- st.push(i);
- }
- else
- {
- r[i]=i;
- st.push(i);
- }
- }
- //for(i=1;i<=n;i++)
- //printf("%d %d\n",l[i],r[i]);
- long long ans=;
- for(i=;i<=n;i++)
- ans=max(ans,(long long)(r[i]-l[i]+)*a[i]);
- printf("%lld\n",ans);
- }
- return ;
- }
QDUOJ LC的课后辅导 单调递增栈的更多相关文章
- qduoj LC的课后辅导
描述 有一天,LC给我们出了一道题,如图: 这个图形从左到右由若干个 宽为1 高不确定 的小矩形构成,求出这个图形所包含的最大矩形面积. 输入 多组测试数据每组测试数据的第一行为n(0 <= n ...
- POJ - 2796 Feel Good 单调递增栈+前缀和
Feel Good Bill is developing a new mathematical theory for human emotions. His recent investigations ...
- nyoj 单调递增子序列(二)
单调递增子序列(二) 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给定一整型数列{a1,a2...,an}(0<n<=100000),找出单调递增最长 ...
- HD1160FatMouse's Speed(最长单调递增子序列)
FatMouse's Speed Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- 最长递增子序列问题 nyoj 17单调递增最长子序列 nyoj 79拦截导弹
一, 最长递增子序列问题的描述 设L=<a1,a2,…,an>是n个不同的实数的序列,L的递增子序列是这样一个子序列Lin=<aK1,ak2,…,akm>,其中k1< ...
- 【LCS,LIS】最长公共子序列、单调递增最长子序列
单调递增最长子序列 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 求一个字符串的最长递增子序列的长度如:dabdbf最长递增子序列就是abdf,长度为4 输入 ...
- nyoj 17 单调递增最长子序列
单调递增最长子序列 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 求一个字符串的最长递增子序列的长度如:dabdbf最长递增子序列就是abdf,长度为4 输入 ...
- NYOJ17,单调递增最长子序列
单调递增最长子序列 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描写叙述 求一个字符串的最长递增子序列的长度 如:dabdbf最长递增子序列就是abdf.长度为4 输入 第 ...
- [LeetCode] Monotone Increasing Digits 单调递增数字
Given a non-negative integer N, find the largest number that is less than or equal to N with monoton ...
随机推荐
- px rem css 转换工具
http://520ued.com/tools/rem mark 一下 貌似还挺好用
- iOS移动开发周报-第20期
iOS移动开发周报-第20期iOS移动开发周报-第20期 [摘要]:本期iOS移动开发周报带来如下内容:iOS 通知中心扩展制作入门,iOS APP可执行文件的组成,objc非主流代码技巧等. 教程 ...
- java 文件的写入和读取
//写入操作 方法1 OutputStream f = new FileOutputStream("C:/j/j.txt"); f.write("aaaaaaa" ...
- 去除input框的值
onfocus="this.value=' ';" <input type="text" name="buynum" id=" ...
- window下Jira+SQL Server部署+汉化+破解
网上很多都是jira+mysql部署的文章,由于我现在有需求要用SQL Server数据库,因此就动手试了一下,参考网上许多文章,再加上自己的几次尝试,很快也成功了,分享出来. 全文章节: 一.事前准 ...
- Oracle中如何进行进制转换(2进制,10进制,16进制)
1.16进制转换为10进制 可以通过to_number函数实现 SQL> select to_number('19f','xxx') from dual; TO_NUMBER('19F','XX ...
- makefile编写---.c .cpp 混合编译makefile 模板
# c.cpp混合编译的makefile模板 # # BIN = client_system BASE_INSTALL_DIR := /opt/arm-2009q1 BUILD_TOOL_DIR := ...
- 使用kbmmw 的调度事件动态显示时间
kbmmw 里面提供了强大的事件调度功能,今天简单演示一个使用调度事件在窗体上显示时间. 建立一个新工程. 放上几个控件 在窗体里面引用单元 kbmMWScheduler, 然后添加过程 unit U ...
- 2018.11.22-day24 面向对象-继承
1.归一化设计 2.抽象类 3.钻石继承 4.C3算法 5.新式类中的super
- C++笔记之外部类访问内部类的私有成员
如下图所示 内部类可以访问外部类的私有成员 而外部类无法访问内部类的私有成员 为了能让外部类访问内部类的私有成员,将外部类声明为内部类的友元类即可 #include <iostream> ...