51nod 1279 扔盘子
如果上面一层窄,下面再宽也没用。
那么可以根据输入获得一个单调的栈,这个栈是经过选择的。比如输入例子的5 6 4 3 6 2 3,将变成5 5 3 3 3 2 2 。最后一层为栈顶,接着来一个盘子判断栈顶(亦即坑底部)能否容纳,不可则出栈再判断,可则认为放置这个盘子入这层,这层消失。统计一下放置了多少次即可。
#include <bits/stdc++.h> using namespace std; const int maxN = 1e5 + 5; int N, M, S; int stk[maxN], p; int main() { #ifndef ONLINE_JUDGE freopen("data.in", "r", stdin); #endif scanf("%d%d", &N, &M); p = 0; for (int i = 0; i < N; ++i) { scanf("%d", &S); if (p) stk[p] = min(stk[p - 1], S); else stk[p] = S; ++p; } int ans = 0; for (int i = 0; i < M; ++i) { scanf("%d", &S); while (p && stk[p - 1] < S) --p; if (!p) break; ++ans; --p; } printf("%d\n", ans); return 0; }