发型糟糕的一天(简单的单调栈运用)

5 篇文章 1 订阅

提供两种解法,比较类似
一种是从后向前维护单调递增栈;
另一种是从前向后维护单调递减栈.

描述
农夫John 的N(1 ≤ N ≤ 80,000)只奶牛中,有一些也许正在经历发型糟糕的一天。每只奶牛对自己乱糟糟的发型都有自知之明,农夫John想知道所有奶牛能看到其他奶牛头顶的数量之和。

任意奶牛i身高记为 hi (1 ≤ hi ≤ 1,000,000,000),所有奶牛面向东方(本题示意图的右面)依次站成一条线。因此,奶牛i能够看到在它前面的(奶牛i+1,i+2…)所有身高比它低的奶牛,直到被一头比它高的奶牛挡住

考虑如下的例子:

        =
=       =
=   -   =         Cows facing right ->
=   =   =
= - = = =
= = = = = =
1 2 3 4 5 6 
奶牛#1 可以看见奶牛#2, 3, 4的头顶

奶牛#2 无法看到任何奶牛的头顶

奶牛#3可以看见奶牛#4的头顶

奶牛#4无法看到任何奶牛的头顶

奶牛#5可以看见奶牛#6的头顶

奶牛#6无法看到任何奶牛的头顶!

用ci表示奶牛i能够看到头顶的奶牛个数;请计算c1 至cN的和。对于上面这个例子,其和为:3 + 0 + 1 + 0 + 1 + 0 = 5。

输入
第1行:奶牛数N

第2行至N+1行:第i+1行包含一个整数,表示奶牛i的高度

输出
第1行:c1 至cN的累加和

样例输入
6
10
3
7
4
12
2

样例输出
5
/*
 解法1#include <stack>
#include <iostream>
#include <stdio.h>
using namespace std;

int N;
long long res, height[81000], num[81000];

int main()
{
    cin>>N;
    stack<long long> s;
    for(int i=0;i<N;i++)
        scanf("%lld",&height[i]);
    height[N] = 1000000001;
    s.push(N);
    for(int i=N-1;i>=0;i--)
    {
        while(height[i] > height[s.top()])
            s.pop();
        num[i] = s.top()-i-1;
        res += num[i];
        s.push(i);
    }
    printf("%lld\n",res);
    return 0;
}
*/

/*
解法二:
 #include <stack>
 #include <iostream>
 using namespace std;
 int main()
 {
    long long n,h,sum=0;
    cin >> n;
    stack<int>s;
    cin >> h;
    s.push(h); n -= 1;
    while (n--)
    {
 cin >> h;
 while (!s.empty() && h >= s.top())
 {
 s.pop();
 }
 sum += s.size();
 s.push(h);
    }
    cout << sum << endl;
    return 0;
 }
*/
  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值