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

解题思路

  • 将问题转化:一个区间乘积的二进制末尾有 ≥k 个 0,等价于该区间内所有元素的 2 的因子个数之和 ≥ k。 记 v2(x) 为 x 被 2 整除的次数(即二进制尾随零个数),则区间 [l,r] 满足条件 ⇔ sum(v2(a[l..r])) ≥ k。

  • 算法:

    1. 预处理得到数组 b[i] = v2(a[i])(非负整数);
    2. 因为 b[i] ≥ 0,可用 滑动窗口/双指针:右指针不断右移累加窗口和 s;当 s ≥ k 时,尝试移动左指针缩小窗口并更新答案的最小长度。
  • 若整个数组 b 的总和都 < k,则不存在满足条件的子数组,输出 -1(若题目平台有其他约定,可按平台改动)。

P3785.最小K0序列

    1000ms Tried: 171 Accepted: 58 Difficulty: 4
    算法与标签>双指针

题目描述

K0序列是指,序列中元素的乘积转换为2进制后末尾至少有 kkk 个0。

给定一个长度为 nnn 的序列 aaa 和 kkk 值,求其中为K0序列的连续子序列的最小长度。

输入描述

输入第一行两个正整数 n,kn,kn,k 。(3≤n≤105,1≤k≤1053 \leq n \leq 10^5,1 \leq k \leq 10^53≤n≤105,1≤k≤105)

输入第二行 nnn 个正整数,第 iii个为 aia_iai​ 。(1≤ai≤1091 \leq a_i \leq 10^91≤ai​≤109)

输出描述

输出一个正整数 ,表示连续子序列的二进制不小于 kkk 的长度。

样例

样例输入

7 3
1 2 3 4 5 6 7

样例输出

3

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


ScanQRCodePrompt

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

Forgot password or username?