1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析
会员专享
请先登录,登录后可使用今日免费解锁; 开通会员,或 购买 该题目所属题库(美团机考编程题库) ,可解锁完整内容。
购买题库 开通会员

解题思路

放置时只关心每个堆最上面的猫猫虫大小。设数组 toptoptop 表示每个堆的堆顶大小。

由于每次选择的是第一个堆顶大小 >>> 当前大小 xxx 的堆,因此 toptoptop 始终是非递减的:

  • 若找到某个位置 pospospos,则把 top[pos]top[pos]top[pos] 改成 xxx;
  • 若找不到,说明所有堆顶都 ≤x\le x≤x,就在末尾新建一个堆。

P4957.第1题-猫猫虫堆的异或和

    1000ms Tried: 13 Accepted: 4 Difficulty: 5 所属公司 : 美团
    算法与标签>模拟

题目内容

猫猫虫们喜欢在别人的身上睡觉。从左到右有无限多个可以堆猫猫虫的位置(我们称为"堆")。接下来会依次走来 nnn 只猫猫虫,第 iii 只猫猫虫的大小为 aia_iai​。放置规则如下:

  • 从第一个堆开始向右依次检查;
  • 如果当前堆为空,或者该堆最上面的猫猫虫大小 >>> 当前猫猫虫大小,则把当前猫猫虫放到这个堆的最上面;否则继续检查下一个堆;
  • 如果一路检查到某个空堆,那么就在该空堆新建一个堆并把当前猫猫虫放上去。

在每次放置完一只猫猫虫后,记每个堆的高度(即堆中猫猫虫的只数),请你输出当前所有堆的高度的异或和(即所有高度按位异或的结果)。

输入描述

每个测试文件均包含多组测试数据。第一行输入一个整数 TTT (1≤T≤2×1051 \le T \le 2 \times 10^51≤T≤2×105) 表示数据组数,每组测试数据描述如下:

  • 第一行输入一个整数 nnn (1≤n≤4×1051 \le n \le 4 \times 10^51≤n≤4×105) 表示猫猫虫的数量。
  • 第二行输入 nnn 个整数 a1,a2,…,ana_1,a_2,\dots,a_na1​,a2​,…,an​ (1≤ai≤1091 \le a_i \le 10^91≤ai​≤109) 表示每只猫猫虫的大小。 除此之外,保证单个测试文件的 nnn 之和不超过 4×1054 \times 10^54×105。

输出描述

对于每一组测试数据,新起一行。输出 nnn 个整数(以空格隔开),其中第 iii 个数表示放置完前 iii 只猫猫虫后,所有堆的高度的异或和。

样例1

输入

2
5
3 3 2 2 1
4
1 2 3 4

输出

1 0 3 0 1
1 0 1 0

说明

  • 对于第一组数据 n=5n=5n=5,a={3,3,2,2,1}a = \{3,3,2,2,1\}a={3,3,2,2,1},每次放置后的堆高度序列依次可能为 {1}\{1\}{1}、{1,1}\{1,1\}{1,1}、{2,1}\{2,1\}{2,1}、{2,2}\{2,2\}{2,2}、{3,2}\{3,2\}{3,2},对应的异或和依次为 111、000、333、000、111,与输出一致。
  • 对于第二组数据 a={1,2,3,4}a = \{1,2,3,4\}a={1,2,3,4},每次都会新建一个堆,堆高度序列依次为 {1}\{1\}{1}、{1,1}\{1,1\}{1,1}、{1,1,1}\{1,1,1\}{1,1,1}、{1,1,1,1}\{1,1,1,1\}{1,1,1,1},异或和依次为 111、000、111、000。

登录后即可使用 AI 分析。

    模式
    倒计时时长
    :

    最长 10 小时 59 分;应用后按此时长重新开始。

    提示:点击提交记录在左侧题面区域查看详情
    题库
    AI分析设置
    留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
    会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
    升级会员,可将运行与提交冷却时间缩短至 1 秒起

    Status

    • Judging Queue
    • Service Status

    Development

    • Open Source

    Support

    • Help
    • Contact Us

    About

    • About
    • Privacy
    • Terms of Service
    • Copyright Complaint
    1. Language
      1. English
      2. 한국어
      3. 简体中文
      4. 正體中文
    2. Legacy mode
    3. Theme
      1. Light
      2. Dark
    1. 京ICP备2025123107号-1
    2. Worker 0, 43ms
    3. Powered by Hydro v5.0.0-beta.18 Community

    Don't have an account?

    By signing up a CodeFun2000 universal account, you can submit code and join discussions in all online judging services provided by us.

    Sign Up Now
    CLOSE

    SIGN IN

    Using your CodeFun2000 universal account

    Login with Wechat
    Forgot password or username?