12.2学习打卡

学习时间与内容:

  • 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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值