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

解题思路

给定严格递增且互不相同的正整数数组,要求统计所有非空子序列,使得子序列中相邻两个元素的差都不等于 1。 由于数组有序且无重复,当我们把某个元素 a[i] 追加到一个已合法的子序列末尾时,唯一可能产生违例的情况就是前一个被选中的元素等于 a[i]-1。而 a[i]-1 若存在,只可能是 a[i-1](因为数组严格递增)。因此只需分两类讨论:

  • 若 a[i] == a[i-1] + 1:新子序列末尾不能是 a[i-1],因此可追加的前缀子序列只能来自前 i-2 个元素。
  • 否则:数组中不存在值为 a[i]-1 的元素,a[i] 可以接在前 i-1 个元素形成的任意合法子序列后面。

据此设计简单 DP:

P4248.第2题-非空子序列总数对

    1000ms Tried: 59 Accepted: 8 Difficulty: 5 所属公司 : oppo
    算法与标签>动态规划

题目内容

给定一个长度为 nnn 的正整数数组 aaa ,数组已按升序排列目元素互不相同 (ai<ai+1)(a_i<a_{i+1})(ai​<ai+1​) 。

统计所有非空子序列(保持原序),使得子序列中任意相邻两个元素之差均不等于 111 的方案数。由于答案可能很大,请对 109+710^9+7109+7 取模后输出。

【名词解释】 子序列为从原序列中删除任意个(可以为零、可以为全部)元素得到的新序列。

输入描述

第一行输入整数 T(1≦T≦103)T(1 ≦ T ≦ 10^3)T(1≦T≦103) ,表示测试用例数。

接下来 TTT 组数据,每组两行:

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

2.第二行输入 nnn 个两两互不相同且升序的正整数 ai(1≦ai≦109)a_i(1 ≦a_i≦ 10^9)ai​(1≦ai​≦109) ;

保证所有测试用例中 ∑n≦2×105\sum n≦2×10^5∑n≦2×105 。

输出描述

对于每组测试数据,输出一个整数——满足条件的非空子序列总数对 109+710^9+ 7109+7 取模的结果。

样例1

输入

2
5
1 2 4 5 7
4
1 2 3 4

输出

17
7

说明

对于 [1,2,3,4][1,2,3,4][1,2,3,4] ,有 777 个满足条件的非空子序列:

{111},{222},{333},{444},{1,31,31,3},{2,42,42,4},{1,41,41,4} 。

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


ScanQRCodePrompt

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

Forgot password or username?