SDUT 3661 MoutainTop (单调栈) -- 解题报告

原创 2016年08月30日 18:32:02

题面

MoutainTop
Time Limit: 1000MS Memory Limit: 65536KB

Problem Description
金石山脉有n个山峰,一字排开,从西向东依次编号为1, 2, 3, ……, n。编号为i的山峰高度为hi。每个山峰的高度两两不同
小木示从西向东依次爬过这n个山峰,到每一个山峰的山顶的时候,他都会往西边眺望,并且会记录下自己能看到的山峰的个数。
(比如说小木示现在在4号山峰,前四号山峰的高度分别为9,4,5,1。他现在能看到的山峰个数就是2,因为第二个山峰被第三个山峰挡住了)
严格的来说,小木示在i位置的时候,对于一个山峰j (j < i),如果不存在一个山峰k满足hj < hk (j < k < i)。则山峰j是可见的。
小木示把自己记录的山峰的个数加和作为这次爬山的快乐值,现在给你n个山峰的高度,求小木示的快乐值。

Input
多组输入,首先输入一个n(1<=n<=10^6),表示山峰的个数。 接下来一行n个数,表示对应山峰的山峰的高度(1<=h<=10^6)。

Output
输出小木示的快乐值

Example Input
4
1 6 5 1

Example Output
4

Author
JueChen

所需基础

单调栈

解题思路

这道题是小木示出的题,学过单调栈的同学不难看出是一道裸题(我当时怎么就没看出来啊 QAQ)。解题思路其实很容易理解,我们维护一个栈来记录当前可见的山,读入山高数据之后,把栈中所有比当前山高小的元素全部弹出(道理不难理解,一旦出现了高山,那么下一次计算数量的时候,比此山矮的山必然会被挡住,也就不会被计算到,因此可以把它们安全弹出),然后再将当前山高入栈。由于本轮读入的山高只会影响到下一次计数,因此我们可以在每轮输入前进行计数累加。
另外,关于单调栈,再推荐一道类似题目: POJ 3250 Bad Hair Day

参考代码

#include <cstdio>
#include <stack>
using namespace std;

int main(int argc, char const *argv[]) {
    int n, data;
    while(~ scanf("%d", &n)) {
        scanf("%d", &data);
        stack<int> s;
        s.push(data);
        long long sum = 0;
        while(--n) {
            sum += s.size();
            scanf("%d", &data);
            // 弹出比当前山高小的山
            while(!s.empty() && s.top()<data) {
                s.pop();
            }
            s.push(data);
        }
        printf("%lld\n", sum);
    }

    return 0;
}
版权声明:by bLue. 本文为博主原创文章,未经博主允许不得转载。

[SDUT 3661] 山峰

一句话题意: N座山峰,从左向右爬,每爬一座山向左看,右边高的山能挡住左边矮的山,求每次看见的山的数量之和。分析 这个题,看了一眼就认定是dp的题了,用dp怼了好一顿子也没做出来。一查是用栈模拟…...
  • sdutstudent
  • sdutstudent
  • 2017年07月25日 21:22
  • 93

SDUT 3661 山峰

山峰 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description金石山脉有n个山峰,一字排开,从西...
  • yyxiangyu
  • yyxiangyu
  • 2017年07月26日 10:46
  • 60

sdut oj 3661山峰

Time Limit: 1000MS Memory Limit: 65536KB Problem Description 金石山脉有n个山峰,一字排开,从西向东依次编号为1, 2, 3...
  • zbspy_ZJF
  • zbspy_ZJF
  • 2017年07月24日 20:04
  • 212

单调栈的介绍以及一些基本性质

单调栈的定义: 单调栈就是栈内元素单调递增或者单调递减的栈,单调栈只能在栈顶操作。 为了更好的理解单调栈,则可将单调栈用生活情形模拟实现,例如: 我们借用拿号排队的场景来说明下。现在有很多人在排队...
  • liujian20150808
  • liujian20150808
  • 2016年02月26日 22:56
  • 6105

单调队列与单调栈用法详解

基本数据结构的应用一 栈和队列 单调栈 单调队列 和  优先队列的应用 1.单调栈 单调栈是指一个栈内部的元素是具有严格单调性的一种数据结构,分为单调递增栈和单调递减栈。 单调栈有两个性质 ...
  • zhelong3205
  • zhelong3205
  • 2017年08月27日 23:32
  • 705

单调栈总结

单调栈总结目录 定义 性质 功能 例题 HDU 1506 HDU 5033 PKU 2796 PKU 3250 定义性质下面引自百度百科 单调递增或单调减的栈,跟单调队列差不多,但是只用到它...
  • WuBaizhe
  • WuBaizhe
  • 2017年04月11日 23:28
  • 708

单调栈的经典应用

A histogram is a polygon composed of a sequence of rectangles aligned at a common base line. The rec...
  • shzhqmeng
  • shzhqmeng
  • 2016年08月13日 20:44
  • 209

单调栈练习题题解

单调栈单调栈顾名思义就是让栈中的元素是单调的,要么递增,要么递减。同样它也满足栈的性质,先进后出。 单调递增栈,则从栈顶到栈底的元素是严格递增的 单调递减栈,则从栈顶到栈底的元素是严格递减的 练习题单...
  • Z_Mendez
  • Z_Mendez
  • 2015年07月30日 20:14
  • 1339

hdu 1506(单调栈实现)

#include #include #include using namespace std; struct node{ int w=1; long long h; }s[100005]; int ...
  • zizahn
  • zizahn
  • 2016年07月24日 11:07
  • 217

HDU-3661(贪心)

Problem Description In a factory, there are N workers to finish two types of tasks (A and B). Each ...
  • qq_23908539
  • qq_23908539
  • 2016年04月29日 15:55
  • 93
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:SDUT 3661 MoutainTop (单调栈) -- 解题报告
举报原因:
原因补充:

(最多只允许输入30个字)