首页 > 代码库 > SPOJDRUIDEOI - Fata7y Ya Warda!【单调栈】
SPOJDRUIDEOI - Fata7y Ya Warda!【单调栈】
题目链接【http://www.spoj.com/problems/DRUIDEOI/en/】
题意:给出n个数,从1到n围城一个环(1和n相连),求每个数左边第一个比他大的第一个下标,右边第一个比他大的下标,若所有的值都没有i大输出-1,-1。
题解:为了构成一个环,把所有的数重复两遍即:1,2,3,4,5,1,2,3,4,5,分别从前到后和从后到前维护单调递减栈即可。注意下标。
#include<bits/stdc++.h> using namespace std; const int maxn = 2e5 + 15; int a[maxn], que[maxn]; int A[maxn], B[maxn]; int T, n, ed, ma; int main () { scanf("%d", &T); while(T--) { scanf("%d", &n); ma = 0; ed = 0; for(int i = 1; i <= n; i++) { scanf("%d", &a[i]); a[i + n] = a[i]; if(ma < a[i]) ma = a[i]; } for(int i = 1; i <= 2 * n; i++) { while(ed && a[que[ed]] < a[i]) { A[que[ed]] = i > n ? i % n : i; ed--; } que[++ed] = i; if(que[1] > n) break; } ed = 0; for(int i = 2 * n; i >= 1; i--) { while(ed && a[que[ed]] < a[i]) { B[que[ed] > n ? que[ed] % n : que[ed]] = i > n ? i % n : i; ed--; } que[++ed] = i; if(que[1] < n) break; } for(int i = 1; i <= n; i++) { if(a[i] == ma) A[i] = B[i] = -1; } for(int i = 1; i <= n; i++) printf("%d %d\n", B[i], A[i]); } return 0; }
SPOJDRUIDEOI - Fata7y Ya Warda!【单调栈】
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。