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

解题思路

核心贪心:能切就立刻切

从左到右维护当前未结束段的 gcd⁡\gcdgcd 与长度。当第一次出现

gcd⁡≤当前长度\gcd \le \text{当前长度} gcd≤当前长度

P3458.第3题-数组的优美段

    1000ms Tried: 65 Accepted: 28 Difficulty: 5 所属公司 : 蚂蚁
    算法与标签>贪心算法

题目内容

给定一个长度为 nnn 的正整数数组 { a1,a2,…,ana_1,a_2,…,a_na1​,a2​,…,an​ } ;

我们称一段连续子数组 al,al+1,...,ara_l,a_{l+1},...,a_ral​,al+1​,...,ar​ ,为 优美段 ,当且仅当这段子数组的 gcd(al,al+1,...,ar)≤r−l+1gcd(a_l, a_{l+1},...,a_r)≤r-l+1gcd(al​,al+1​,...,ar​)≤r−l+1 ;

请将整个数组划分成 kkk 段互不相交的优美段,覆盖原数组每个位置,求使 kkk 最大化,输出最大值 kkk 。

输入描述

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

第一行输入一个整数 T(1≦T≦104)T(1 ≦T ≦ 10^4)T(1≦T≦104) ,表示测试用例的组数;

除此之外,保证所有测试用例的 nnn 之和不超过 2×1052×10^52×105 ;

随后对每组测试数据,按以下格式输入:

  • 第一行输入一个整数 n(1≦n≦2×105)n(1 ≦ n ≦ 2×10^5)n(1≦n≦2×105) ;

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

输出描述

对于每组测试数据,新起一行输出一个整数,表示将数组划分为优美段的最大段数,如果没有任何分割方式输出 -1 。

样例1

输入

2
5
5 4 4 2 1
3
4 4 4

输出

3
-1

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


ScanQRCodePrompt

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

Forgot password or username?