题目描述:
有一个特异性的双端队列,该队列可以从头部或尾部添加数据,但是只能从头部移出数据。
小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到n的顺序加入队列。确保输出时对应的数据已经在队列中。
收起
示例1
输入:
3 head add 1 remove tail add 2
华为校招机试题-最小的调整次数-2023年
于 2023-08-13 10:24:02 首次发布
这道华为校招算法题要求使用双端队列,在添加和移除操作后,使移除顺序为1到n。小A需要找到调整数据顺序的最小次数。输入包含n个添加和移除指令,保证数据1到n按顺序加入队列。解题关键在于利用队列和栈来解决。
摘要由CSDN通过智能技术生成