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分析

题解

  • 结论

    • 设数组为 a1,…,ana_1,\dots,a_na1​,…,an​,最大值为 M=max⁡(ai)M=\max(a_i)M=max(ai​),其二进制长度为 LLL(特别地,当 M=0M=0M=0 时 L=1L=1L=1)。
    • 记按位与为 A=⋀i=1naiA=\bigwedge_{i=1}^n a_iA=⋀i=1n​ai​,定义掩码 mask=2L−1mask=2^L-1mask=2L−1。
    • 使总和最大的最小初始 xxx 为:

    image

P3388.第1题-非负整数数组

    1000ms Tried: 103 Accepted: 42 Difficulty: 6 所属公司 : 美团
    算法与标签>位运算

题目内容

小美有一个长度为 nnn 的数组 {a1,a2,...,ana_1,a_2,...,a_na1​,a2​,...,an​} ,他希望构造一个非负整数 xxx , 满足 xxx 的二进制位数不超过数组中最大值的二进制位数(特别的 000 二进制位数为 111 )。

随后,可对数组 aaa 重复进行以下操作,以使所有元素的总和最大:

  • 选择一个下标 iii ,同时将 aia_iai​ 修改为 aia_iai​ ororor xxx ,将 xxx 修改为 aia_iai​ andandand xxx 。

在使元素总和达到最大值的前提下,要求所有操作前初始的 xxx 尽可能小。请输出最大总和及对应的最小 xxx 。

按位或:ororor 表示按位或运算,即对两个整数的二进制表示的每一位进行逻辑或操作。

按位与:andandand 表示按位与运算,即对两个整数的二进制表的每一位进行逻辑与操作。

输入描述

每个测试文件均包含多组测试数据。

第一行输入一个整数 T(1≦T≦1000)T(1≦T≦1000)T(1≦T≦1000) ,代表数据组数;

对于每组测试数据,输入如下:

第一行输入一个整数 n(1≦n≦500)n(1 ≦ n≦ 500)n(1≦n≦500) ,表示数组的长度;

第二行输入 nnn 个整数 a1,a2,...,an(0≦ai<230)a_1, a_2,...,a_n(0 ≦ a_i< 2^{30})a1​,a2​,...,an​(0≦ai​<230),表示数组 aaa 的元素。

输出描述

对于每组测试数据,新起一行,输出两个整数,用空格分隔:第一个整数为数组可以达到的最大总和;第二个整数为在达到最大总和的前提下初始最小的 xxx 。

样例1

输入

2
2
3 3
3
1 2 3

输出

6 0
9 3

登录后即可使用 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, 42ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?