学习时间与内容:
- 14:30-16:00刷题
- 19:00-22:30 单调栈,合法的出栈序列
- 总学习5个小时,刷题4题
1 合法的出栈序列
主要思路是记录与输入的取值顺序栈顶的值,与输入的值进行对比,若输入值大于栈顶,则可以出栈,否则不能出栈
#include<stdio.h>
#include<string.h>
int main() {
int n;
while (scanf("%d", &n) != -1) {
int t = 1;
if (n == 0)break;
int a[110] = {0};
int b[110] = {0};
int max = 0;
for (int i = 1; i <= n; i++) {
scanf("%d", &a[i]);
}
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= a[i]; j++) {
if (b[j] != -1) b[j] = j ;
}
b[a[i]] = -1;
if (max <= a[i]) {
for (int j = 1; j <= n; j++) {
if (b[j] != 0 && b[j] != -1) {
max = b[j];
}
}
} else {
t = 0;
break;
}
}
if (t == 1)printf("Yes\n");
if (t == 0)printf("No\n");
}
}
2 栈的优化:单调栈
应用于类似视野问题等
思路为:有一组数10,3,7,4,12。从左到右依次入栈,则如果栈为空或入栈元素值小于栈顶元素值,则入栈;否则,如果入栈则会破坏栈的单调性,则需要把比入栈元素小的元素全部出栈。单调递减的栈反之。目的为保持栈的单调性。
3 二分法
前提:数据有序
例:2 3 3 5 7 9
可以定左边界l=0,右边界r=5,mid=(i+r)/2
若需要寻找的值大于mid,则l=mid+1,反之r=mid