华为OD-2024年E卷-最小的调整次数[100分] -- python

问题描述:

有一个特异性的双端队列,该队列可以从头部或尾部添加数据,但是只能从头部移出数据。小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要调整的最小次数。

3
head add 1
remove 
tail add 2
head add 3
remove
remove
1

解题思路:

不要被双端队列模拟吓到了,先看规则:

  1. head add i 是头部添加数据
  2. tail add i 是尾部添加数据
  3. remove是删除头部数据

要求顺序添加1-n,顺序删除1-n,顺序不对时需要调整顺序,问最小调整次数

那么现在问题是:什么时候才需要调整顺序?

显然,只有head add i 的时候才可能会影响顺序

  1. 如果这个‘双端队列’当前为空,则head和tail效果一致,不会影响
  2. 如果不为空,进行head操作,则会影响顺序,需要调整

那么现在只需要两个条件:

  1. 一个arr_len记录列表长度,用于判定是否为空,head 和 tail 时 +1 ;remove 时 -1 
  2. 一个is_sorted判断是否有序,无序时将其修改为False;进行remove操作时,修改为True,并将ans结果+1

代码实现:

n = int(input())
arr = []#输入操作
ans = 0#记录调整次数
arr_len = 0#长度
is_sorted = True#是否有序
for i in range(2*n):
    s = input()
    if s[0] == 'r':
        if not is_sorted:
            is_sorted = True
            ans += 1
        arr_len -= 1
    elif s[0] == 'h':
        if arr_len != 0:
            is_sorted = False
        arr_len += 1 
    else:
        arr_len += 1
print(ans)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值