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

解题思路

先把式子按二进制位拆开看。

设当前考虑第 kkk 位,权值为 2k2^k2k。 由于按位与、按位异或、按位或都是“逐位独立”计算的,所以这一位对总答案的贡献,只和:

  • aia_iai​ 的第 kkk 位是 000 还是 111
  • sis_isi​ 的类型

P4693.第3题-位运算权值

    1000ms Tried: 26 Accepted: 4 Difficulty: 7 所属公司 : 蚂蚁
    算法与标签>动态规划

题目内容

天才同学给笨蛋同学留下一道小练习:给定一个长度为 nnn 的整数序列 {a1,a2,…,ana_1,a_2,…,a_na1​,a2​,…,an​},以及一个同样长度为 nnn 的字符串 sss,其中每个字符si s_isi​ 只可能是 1,2,31, 2, 3 1,2,3之一。

你需要在区间 [1,r][1,r] [1,r]中选择一个整数 xxx,并据此计算这个序列的"权值和"。对每个位置i ii:

  • 当 si=1s_i=1 si​=1时,该项贡献为 aiaiai&xxx
  • 当si=2 s_i=2 si​=2时,该项贡献为 ai⊕xa_i⊕xai​⊕x
  • 当 si=3s_i=3 si​=3时,该项贡献为 ai∣xa_i∣xai​∣x

定义总权值为:

W(x)=∑i=1nf(ai,x,si)W(x)=∑_{i=1}^nf(a_i,x,s_i)W(x)=∑i=1n​f(ai​,x,si​)

请你求出 maxx∈[1,r]W(x)max_{x∈[1,r]}W(x)maxx∈[1,r]​W(x) 的值。

符号⊕⊕⊕表示按位异或运算(对两个数的二进制逐位异或)对应位不同为111,相同为000。例如5(1012)5(101_2)5(1012​)与3(0112)3 (011_2)3(0112​)满足5 xor 3=6(1102)5\ xor\ 3=6 (110_2)5 xor 3=6(1102​)。

符号&表示按位与运算(对两个数的二进制逐位相与)对应位都为111时结果为111,否则为000。例如5(1012)5(101_2)5(1012​)与3(0112)3 (011_2)3(0112​)满足5 and 3=1(0012)5\ and\ 3=1 (001_2)5 and 3=1(0012​)

符号∣|∣表示按位或运算(对两个数的二进制逐位相或)对应位只要有一个为111结果为111,否则为000。 例如5(1012)5 (101_2)5(1012​)与3(0112)3 (011_2)3(0112​)满足5 or 3=7(1112)5\ or\ 3=7 (111_2)5 or 3=7(1112​)

输入描述

每个测试文件均包含多组测试数据。第一行输入一个整数t(1≤t≤2×105)t(1≤t≤2×10^5)t(1≤t≤2×105)代表数据组数,每组测试数据描述如下

第一行输入两个整数nnn和r(1≤n≤2×105;1≤r≤109)r(1≤n≤2×10^5;1≤r≤10^9)r(1≤n≤2×105;1≤r≤109)。

第二行输入nnn个整数a1,a2,...,an(0≤ai≤109)a_1,a_2,...,a_n(0≤a_i≤10^9)a1​,a2​,...,an​(0≤ai​≤109)

第三行输入一个长度为nnn的字符串sss,保证对所有1≤i≤n1≤i≤n1≤i≤n,都有sis_isi​∈{1,2,31,2,31,2,3}

除此之外,保证单个测试文件的∑n\sum n∑n不超过4×1054×10^54×105

输出描述

对于每一组测试数据,新起一行输出一个整数,表示maxx∈[1,r]W(x)max_{x∈[1,r]}W(x)maxx∈[1,r]​W(x)

样例1

输入

3
3 7
1 2 3 
123
4 3
1 1 1 1
1111
5 10
5 6 7 8 9
23231

输出

15
4
60

说明

数组为 {2,2,3,3,22,2,3,3,22,2,3,3,2}。所有满足i≠j i≠j i=j的有序二元组 (i,ji,ji,j) 共有 5×4=205×4=205×4=20 个。其中满足 ai+aja_i+a_jai​+aj​ 为合数的二元组有:

  • ai=2,aj=2a_i=2,a_j=2ai​=2,aj​=2:和为 2+2=42+2=42+2=4(合数)。由于数组中有 333个 222,可以组成3×2=6 3×2=63×2=6 个这样的有序对。
  • ai=3,aj=3a_i=3,a_j=3ai​=3,aj​=3:和为 3+3=63+3=63+3=6(合数)。由于数组中有2 22 个3 33,可以组成 2×1=22×1=2 2×1=2个这样的有序对。

总计 6+2=86+2=8 6+2=8个。

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


ScanQRCodePrompt

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

Forgot password or username?