[USACO09MAR]Look Up S
题目描述
Farmer John’s N (1 <= N <= 100,000) cows, conveniently numbered 1…N, are once again standing in a row. Cow i has height H_i (1 <= H_i <= 1,000,000).
Each cow is looking to her left toward those with higher index numbers. We say that cow i ‘looks up’ to cow j if i < j and H_i < H_j. For each cow i, FJ would like to know the index of the first cow in line looked up to by cow i.
Note: about 50% of the test data will have N <= 1,000.
约翰的 N ( 1 ≤ N ≤ 1 0 5 ) N(1\le N\le10^5) N(1≤N≤105) 头奶牛站成一排,奶牛 i i i 的身高是 H i ( 1 ≤ H i ≤ 1 0 6 ) H_i(1\le H_i\le10^6) Hi(1≤Hi≤106)。现在,每只奶牛都在向右看齐。对于奶牛 i i i,如果奶牛 j j j 满足 i < j i<j i<j 且 H i < H j H_i<H_j Hi<Hj,我们可以说奶牛 i i i 可以仰望奶牛 j j j。 求出每只奶牛离她最近的仰望对象。
Input
输入格式
- * Line 1: A single integer: N
* Lines 2…N+1: Line i+1 contains the single integer: H_i
第 1 1 1 行输入 N N N,之后每行输入一个身高 H i H_i Hi。
输出格式
* Lines 1…N: Line i contains a single integer representing the smallest index of a cow up to which cow i looks. If no such cow exists, print 0.
共 N N N 行,按顺序每行输出一只奶牛的最近仰望对象,如果没有仰望对象,输出 0 0 0。
样例 #1
样例输入 #1
6
3
2
6
1
1
2
样例输出 #1
3
3
0
6
6
0
提示
FJ has six cows of heights 3, 2, 6, 1, 1, and 2.
Cows 1 and 2 both look up to cow 3; cows 4 and 5 both look up to cow 6; and cows 3 and 6 do not look up to any cow.
【输入说明】 6 6 6 头奶牛的身高分别为 3,2,6,1,1,2。
【输出说明】奶牛 #1,#2 仰望奶牛 #3,奶牛 #4,#5 仰望奶牛 #6,奶牛 #3 和 #6 没有仰望对象。
【数据规模】
对于 20 % 20\% 20% 的数据: 1 ≤ N ≤ 10 1\le N\le10 1≤N≤10;
对于 50 % 50\% 50% 的数据: 1 ≤ N ≤ 1 0 3 1\le N\le10^3 1≤N≤103;
对于 100 % 100\% 100% 的数据: 1 ≤ N ≤ 1 0 5 , 1 ≤ H i ≤ 1 0 6 1\le N\le10^5,1\le H_i\le10^6 1≤N≤105,1≤Hi≤106。
代码及分析如下:
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<string>
#include<istream>
#include<iomanip>
#include<ostream>
#include<list>
#include<vector>
#include<set>
#include<map>
#include<fstream>
#include<stack>
#include<ctime>
#include<deque>
#include<queue>
#include <sstream>
#include <numeric>
#pragma warning (disable:4996)
using namespace std;
int a[100005],b[100005];
int main()
{
int n; cin >> n; stack<int>s;//栈保存从低到高的奶牛,顶最矮,底最高
for (int i = 1; i <= n; i++)
{
cin >> a[i];
}
for (int i = n; i >=1; i--)
{
while (!s.empty() && a[s.top()] <= a[i])//从后往前遍历,如果i的牛比右边的牛还高,则去除它(出栈)直到右边的牛比i牛高
s.pop();
if (s.empty())//右边没牛比他高
{
b[i] = 0;
}
else//栈顶比他高并且栈顶(后进栈)离它最近
{
b[i] = s.top();
}
s.push(i);
}
for (int i = 1; i <= n; i++)
{
cout << b[i] <<endl;
}
}