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 video solution AI分析

思路

关键观察:将区间右端点从 i−1i-1i−1 扩展到 iii 时,任何以 iii 结尾的子区间的按位或,要么等于 aia_iai​,要么是某个以前缀结尾的按位或再与 aia_iai​ 做一次 ∣|∣。并且按位或只会“开新位”不会关掉已有位,因此对于固定右端点 iii,不同的“以 iii 结尾的子区间按位或结果”的种类数是有限的,至多与二进制位数相关。由于 ai≤109a_i\le 10^9ai​≤109,二进制位数 B≤31B\le 31B≤31,所以每个位置最多保留 O(B)O(B)O(B) 个不同的结果。

做法(在线去重):

  • 维护两个集合:

    • SprevS_{\text{prev}}Sprev​:所有“以前一个位置结尾”的按位或结果集合;

P3434.第3题-小红的区间或

    1000ms Tried: 18 Accepted: 9 Difficulty: 4 所属公司 : 阿里
    算法与标签>思维

题目内容

小红有一个长度为 nnn 的数组 aaa ,记子区间 [l,r][l,r][l,r] 的权值为 al∣al+1∣...∣ara_l|a_{l+1}|...|a_ral​∣al+1​∣...∣ar​ ,即区间内所有数的按位或运算的结果。一共有 n×(n+1)/2n×(n+1)/2n×(n+1)/2 个子区间,小红想知道对应的 n×(n+1)/2n×(n+1)/2n×(n+1)/2 个权值中,有多少个不同的取值。

输入描述

第一行一个整数 nnn ,表示数组长度。

第二行 nnn 个整数 a1,a2,...,ana_1,a_2,...,a_na1​,a2​,...,an​ ,表示数组 aaa 的元素。

1≤n≤1051 ≤n≤ 10^51≤n≤105

1≤ai≤1091 ≤ a_i ≤ 10^91≤ai​≤109

输出描述

输出一个整数,表示不同的取值个数。

样例1

输入

3
1 2 4

输出

6

说明

[1,1][1,1][1,1] 的权值为 111

[1,2][1,2][1,2] 的权值为 333

[1,3][1,3][1,3] 的权值为 777

[2,2][2,2][2,2] 的权值为 222

[2,3][2,3][2,3] 的权值为 666

[3,3][3,3][3,3] 的权值为 444

开通会员即可查看完整视频题解: 1.题目讲解 2.思路分析 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 3, 53ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

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

Forgot password or username?