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-山峰

山峰 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 金石山脉有n个山峰,一字排开,...

CODEVS-1531 山峰

题目描述 Description Rocky山脉有n个山峰,一字排开,从西向东依次编号为1, 2, 3, ……, n。每个山峰的高度都是不一样的。编号为i的山峰高度为hi。 小修从西往东登山。每到一...

精选:深入理解 Docker 内部原理及网络配置

网络绝对是任何系统的核心,对于容器而言也是如此。Docker 作为目前最火的轻量级容器技术,有很多令人称道的功能,如 Docker 的镜像管理。然而,Docker的网络一直以来都比较薄弱,所以我们有必要深入了解Docker的网络知识,以满足更高的网络需求。

山峰(单调栈)

山峰 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Discuss Problem Description金石山脉有n个山峰...

山峰 2016暑假集训结训赛 by JueChen 栈的维护

山峰 Time Limit: 1000MS Memory Limit: 65536KB Problem Description 金石山脉有n个山峰,一字排开,从西向东依次编号为1, ...
  • khn64
  • khn64
  • 2017-07-24 20:42
  • 49

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

题面 MoutainTop Time Limit: 1000MS Memory Limit: 65536KB Problem Description 金石山脉有n个山峰,一字...

[SDUT 3661] 山峰

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

Gym 100851E Easy Problemset 解题报告

Gym 100851E Easy Problemset 解题报告

POJ 1363 Rails(栈)

Rails Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 24876   Accepte...

The 14th Zhejiang University Programming Contest(未完工)

The 14th Zhejiang University Programming Contest
  • RaynX
  • RaynX
  • 2014-05-10 23:02
  • 528

HDU3605 匈牙利匹配

这题的时间 卡得很彻底....各种循环优化,外加一个前驱记录,匈牙利匹配的运用。 #include #include #include using namespace std; int n, ...
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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