【华为OD机试 2023】最小调整顺序次数(Python)

文章描述了一个关于特殊双端队列的问题,其中数据只能从头部移除。小A需要按照1到n的顺序移除数据,他有2n个指令,包括在头部或尾部添加数据以及移除数据。提供的Python代码解决了如何计算小A最少需要调整队列多少次以满足顺序移除的问题。
摘要由CSDN通过智能技术生成

题目描述

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

小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 要调整的最小次数。

用例

输入

5
head add 1
tail add 2
remove
head add 3
tali add 4
head add 5
remove
remove
remove
remove

输出

1

Python代码

n = int(input())
ops = [input().split() for _ in range(2 * n)]

queue_size = 0
in_order = True
count = 0
for op in ops:
    if op[0] == "head":
        if queue_size > 0:
            in_order = False
        queue_size += 1
    elif op[0] == "tail":
        queue_size += 1
    elif op[0] == "remove":
        if queue_size == 0:
            continue
        if not in_order:
            count += 1
            in_order = True
        queue_size -= 1
    print(in_order)
print(count)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值