最小的调整次数

题目描述
有一个特异性的双端队列,该队列可以从头部或尾部添加数据,但是只能从头部移出数据。

小A依次执行2n个指令往队列中添加数据和移出数据。其中n个指令是添加数据(可能从头部添加、也可能从尾部添加),依次添加1到n;n个指令是移出数据。

现在要求移除数据的顺序为1到n。

为了满足最后输出的要求,小A可以在任何时候调整队列中数据的顺序。

请问 小A 最少需要调整几次才能够满足移除数据的顺序正好是1到n;

输入描述
第一行一个数据n,表示数据的范围。

接下来的2n行,其中有n行为添加数据,指令为:

“​head add x” 表示从头部添加数据 x,
​"​tail add x" 表示从尾部添加数据x,
另外 n 行为移出数据指令,指令为:“remove” 的形式,表示移出1个数据;

1 ≤ n ≤ 3 * 10^5。

所有的数据均合法。

输出描述
一个整数,表示 小A 要调整的最小次数。

用例1
输入
5
head add 1
tail add 2
remove
head add 3
tail add 4
head add 5
remove
remove
remove
remove
输出
1

#这题最难的点是如何理解题意
#小A可以在任何时候调整队列中数据的顺序应该理解为这次调整直接让队列有序
#这样这题的难度就明显下降
#队列为空是head add 和tail add都不需要调整
#非空时,tail add不需要调整,head tail需要调整

n= int(input())
orders = [input() for i in range(2*n)]
size = 0
isSorted = True #默认有序
count=0
for order in orders:
    if order.startswith('head add'):
        if size>0 and isSorted:
            isSorted = False
        size+=1
    elif order.startswith('tail add'):
        size+=1
    else:#移除
        if size<=0:
            continue
        if not isSorted:
            count+=1
            isSorted = True
        size-=1
print(count)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值