题目链接:
http://codeforces.com/contest/1092/problem/D1
http://codeforces.com/contest/1092/problem/D2
题意:
希望用$2\times 1$的砖头搭出一面长为$n$并且每一个单位长度高度为$a_i$的墙,现在允许的操作是:
D1:横、竖都允许放
D2:只允许横着放
问是否能搭出指定高度的墙?
D1:可以贪心,由于当两个相邻的墙高度的奇偶性相同的时候,那么这两个墙可以看做一面墙,并且高度可以任意(允许任意+1)。于是我们考虑维护一个栈,从左到右贪心地判断当前墙是否与栈顶的墙高度的奇偶相同,如果相同则配对出栈,否则入栈等待与它配对的墙。当栈内为空或只有一个高度的时候(此时这个高度可以搭成比之前所有墙都高的情况,并且前面的墙总可以+1到这个高度),则说明可以搭出指定高度的墙。
1 |
|
D2:考虑只允许横着放,那么只有在两个块一样高的时候才能+1. 于是考虑扫到每一个数的时候是否与栈顶这个数相同,如果相同的话则可以配对出栈;否则讨论一下大小:如果当前块比栈顶的高,那就不会再有机会更新到栈顶那个块,于是这种情况下是没有解的,否则还是有可能存在解的。有一个cha点在输出前,如果栈内存在元素那么这个块一定是最高的(其他所有块结对后+1直到这个块),否则是没有解的。
1 |
|