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

解题思路

给定长度为 n 的数组,需要统计所有元素互不相同的非空子数组数量。 核心做法是双指针滑动窗口 + 计数:

  • 用两个指针 l、r 表示当前窗口 [l, r],并维护每个数在窗口中的出现次数(可用数组或哈希表,因数据范围 1 ≤ a[i] ≤ n,用数组更高效)。
  • 右指针 r 逐步右移并加入元素;如果某个元素出现次数变为 2(产生重复),就不断移动左指针 l 并减少对应计数,直到窗口内再次全为互异元素。
  • 当以 r 为右端时,所有满足条件且以 r 结尾的子数组个数正是窗口长度 r - l + 1,累加到答案即可。

P3838.第2题-子数组

    1000ms Tried: 26 Accepted: 18 Difficulty: 3 所属公司 : 蚂蚁
    算法与标签>双指针

题目内容

给定一个长度为 nnn 的数组 {a1,a2,...,ana_1,a_2,...,a_na1​,a2​,...,an​},请你计算其中所有子数组中,元素互不相同的子数组个数。

子数组指从原数组中连续选择的一段元素所形成的数组,要求非空。

输入描述

第一行输入一个整数 n(1≤n≤2×105)n(1 ≤n ≤2× 10^5)n(1≤n≤2×105),表示数组长度。

第二行输入 nnn 个整数 a1,a2,...,an(1≤ai≤n)a_1,a_2,...,a_n(1 ≤a_i≤n)a1​,a2​,...,an​(1≤ai​≤n) ,表示数组中的元素。

输出描述

输出一个整数,表示满足条件的子数组个数。

样例1

输入

3
1 2 1

输出

5

说明

所有子数组共 3×4/2=63×4/2=63×4/2=6 个:

  • [1,1]=[1,1]=[1,1]={111} 合法;[1,2]=[1,2]=[1,2]={1,21,21,2} 合法;[1,3]=[1,3]=[1,3]={1,2,11,2,11,2,1} 存在重复 111 ,不合法;[2,2]=[2,2]=[2,2]={222} 合法;[2,3]=[2,3]=[2,3]={2,12,12,1} 合法;[3,3]=[3,3]=[3,3]={111} 合法。

  • 合法子数组共有 555 个,故答案为 555 。

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


ScanQRCodePrompt

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

Forgot password or username?