传送门http://poj.org/problem?id=2796

题意:给你一串数字,需要你求出(某个子区间乘以这段区间中的最小值)所得到的最大值

例子:

6

3 1 6 4 5 2

L=3,R=5时这段区间总和为6+4+5=15,最小值为4,所以最后的结果为60.

思路:单调栈的板子题了。没学过单调栈的我只能现学了。单调栈分为单调递增栈,单调递减栈。而这个题呢,要用到单调递增栈。怎么维护单调栈呢?那就是在遇到一个元素大于栈顶元素时,就将该元素加入栈中。(假定即为区间最小值,区间左端点L=i,区间右端点R=i)如果遇到一个小于栈顶的元素时,则把栈里面的元素弹出来,同时记录该元素向左延申的最大长度,即更新区间左端点。在弹出栈顶元素时把这个要弹出栈的元素(栈顶元素)的右端点赋值给这个它的下一个元素(当前栈中次大元素),即更新区间右端点,同时更新答案。

#include<iostream>
#include<cstdio>
using namespace std;
const int maxn = 1e6 + 10;
struct node
{
int l;
int r;
long long num;
} s[maxn];
long long a[maxn];
long long sum[maxn];
long long ans;
int ans_l;
int ans_r;
int top;
int n;
void solve(int top)
{
int l = s[top].l;
int r = s[top].r;
//更新答案
if((sum[r] - sum[l - 1])*s[top].num >= ans)
{
ans = (sum[r] - sum[l - 1]) * s[top].num;
ans_r = r;
ans_l = l;
}
//向右延申
if(top > 0)
{
s[top - 1].r = s[top].r;
}
}
int main()
{
scanf("%d", &n);
for(int i = 1; i <= n; i++)
{
scanf("%I64d", &a[i]);
//记录前缀和
sum[i] = a[i] + sum[i - 1];
}
top = -1;
for(int i = 1; i <= n; i++)
{
//初始假定a[i]为区间最小值,左区间,右区间都为i
node v;
v.l = i;
v.r = i;
v.num = a[i];
//加入的元素大于栈顶元素向左延申
while(top != -1 && s[top].num >= a[i])
{
solve(top);
//一直向左更新 ,直到某一个元素小于加入的元素
v.l = s[top].l;
top--;
}
s[++top].l = v.l;
s[top].r = v.r;
s[top].num = a[i];
}
//单调栈中元素可能不为空
while(top != -1)
{
solve(top);
top--;
}
cout << ans << endl;
cout << ans_l << " " << ans_r << endl;
}

POJ 2796 Feel Good 【单调栈】的更多相关文章

  1. poj 2796 Feel Good单调栈

    Feel Good Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 20408   Accepted: 5632 Case T ...

  2. poj 2796 Feel Good 单调栈区间问题

    Feel Good 题意:给你一个非负整数数组,定义某个区间的参考值为:区间所有元素的和*区间最小元素.求该数组中的最大参考值以及对应的区间. 比如说有6个数3 1 6 4 5 2 最大参考值为6,4 ...

  3. POJ 3658 Artificial Lake (单调栈)

    题意: 析:利用单调栈,维护一个单调递增的栈,首先在最低的平台开始,每次向两边进行扩展,寻找两边最低的,然后不断更新宽度. 代码如下: #pragma comment(linker, "/S ...

  4. poj 2559 Largest Rectangle(单调栈)

    Largest Rectangle in a Histogram Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 26549 ...

  5. POJ - 2796 Feel Good 单调递增栈+前缀和

    Feel Good Bill is developing a new mathematical theory for human emotions. His recent investigations ...

  6. POJ 3415 后缀数组+单调栈

    题目大意: 给定A,B两种字符串,问他们当中的长度大于k的公共子串的个数有多少个 这道题目本身理解不难,将两个字符串合并后求出它的后缀数组 然后利用后缀数组求解答案 这里一开始看题解说要用栈的思想,觉 ...

  7. poj 2796 Feel Good 单调队列

    Feel Good Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 8753   Accepted: 2367 Case Ti ...

  8. [poj 2796]单调栈

    题目链接:http://poj.org/problem?id=2796 单调栈可以O(n)得到以每个位置为最小值,向左右最多扩展到哪里. #include<cstdio> #include ...

  9. POJ 2796:Feel Good(单调栈)

    http://poj.org/problem?id=2796 题意:给出n个数,问一个区间里面最小的元素*这个区间元素的和的最大值是多少. 思路:只想到了O(n^2)的做法. 参考了http://ww ...

随机推荐

  1. linux命令之strace简单使用

    strace是什么 strace是一个可用于诊断.调试和教学的Linux用户空间跟踪器.我们用它来监控用户空间进程和内核的交互,比如系统调用.信号传递.进程状态变更等. 使用方式 strace 使用帮 ...

  2. 算法实战(六)Z 字形变换

    一.前言 之前因为第五题最长回文字符串需要使用到dp解法,所以我花了很长的时间来研究dp(因为每天又要上班,加上这段时间事情比较多,所以花了三个星期才搞定),好不容易算入了个门,有兴趣的同学可以看看我 ...

  3. robotframework+selenium2Library怎样不用手动关掉代理

    每次跑脚本,启动浏览器都要手动关掉代理,太费劲了,发现最简单的办法就是在局域网设置里面勾上跳过本地地址的代理服务器,并且在例外里写上127.0.0.1 就这么简单有没有??

  4. python_re正则表达

    re模块就本质而言,正则表达式(或RE)是一种小型的.高度专业化的编程语言,(在python中)它内嵌在Python中,并通过re模块实现,正则表达式模块被编译成一系列的字节码,然后由用C编写的匹配引 ...

  5. 详解contextConfigLocation|Spring启动过程详解(转)

    原文链接:https://blog.csdn.net/qw222pzx/article/details/78191670 spring的应用初始化流程一直没有搞明白,刚刚又碰到了相关的问题.决定得好好 ...

  6. 十七、CI框架之数据库操作insert用法

    一.代码如下: 二.我们访问一下页面 三.查看数据库,已经插入了一条数据 不忘初心,如果您认为这篇文章有价值,认同作者的付出,可以微信二维码打赏任意金额给作者(微信号:382477247)哦,谢谢.

  7. Java 语言特性【一】——JUC(Java 并发工具包)

    引言 JUC即java.util.concurrent,是java提供的用于多线程处理的工具类库.重点关注 ConcurrentXXX.AtomicXXX.Executor.Caller&&a ...

  8. python3.4+Django+pymysql

    pip install Pymysql 修改app里面的__init__.py import pymysqlpymysql.install_as_MySQLdb()

  9. ArrayList 和 LinkedList 比较

    是否保证线程安全? ArrayList 和 LinkedList 都是不同步的,也就是不保证线程安全. 底层数据结构区别? Arraylist 底层使用的是Object数组:LinkedList 底层 ...

  10. vue 动画原理 part1

    Vue动画原理 增加和删除css增加样式实现一个过渡效果也就是动画效果 1.需要动画效果的标签外包裹一个transition标签 会被自动分析css样式,然后自动构建一个动画流程 transition ...