题解 | 锁

https://www.nowcoder.com/practice/d0917045d3ab43ac98fcd7dfa8b8afb7

考核知识点:思维、贪心、暴力

使用一个布尔数组或字符数组记录每个资源的上锁状态。初始化时所有资源都未上锁。维护两个计数器,一个用于统计区间[1,x]中未上锁资源的数量,另一个用于统计区间[y,N]中未上锁资源的数量。

下述代码请用Pypy3语言运行。

t = int(input())
for _ in range(t):
    n, m, x, y = map(int, input().split())
    locks = [False] * (n + 1)
    a1 = 0
    a2 = 0
    a1 = x
    a2 = n - y + 1
    for _ in range(m):
        p = int(input())
        locks[p] = not locks[p]
        if p <= x:
            a1 += 1 if not locks[p] else -1
        if p >= y and p <= n:
            a2 += 1 if not locks[p] else -1
        print(a1, a2)

全部评论

相关推荐

程序员花海:实习和校招简历正确格式应该是教育背景+实习+项目经历+个人评价 其中项目经历注意要体现业务 实习经历里面的业务更是要自圆其说 简历模板尽可能保持干净整洁 不要太花哨的
点赞 评论 收藏
分享
12-19 16:52
门头沟学院
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务