2021百度之星初赛一

1006 毒瘤数据结构题
分析:注意第一个和第二个0的位置即可

#include <bits/stdc++.h>
using namespace std;
const int maxn = 5e6+10;.
int n, p1, p2, a[maxn];
// p1 : 第一个 0, p2 : 第二个 0
int main() {
    scanf("%d", &n);
    p1 = 1, p2 = 2;
    for (int i = 1; i <= n; i++) {
        int op, x; scanf("%d%d", &op, &x);
        if (op == 1) {
            a[x] = 1;
            if (x == p1) {
                p1 = p2; p2 = p1 + 1;
                while (a[p2]) ++ p2;
            } else if (x == p2) {
                while (a[p2]) ++ p2;
            }
        } else {
            if (x == p1) printf("%d\n", p2);
            else printf("%d\n", p1);
        }
    }
    return 0;
}
全部评论

相关推荐

11-30 11:07
河南大学 Java
宇宙厂 测开 n*15
丘丘给个offer:有后选后
点赞 评论 收藏
分享
与火:这不接? 留子的钱不挣白不挣
点赞 评论 收藏
分享
宇智波爱学习:我还没收到笔试
投递荣耀等公司10个岗位
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-26 15:46
已编辑
字节国际 电商后端 24k-35k
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务