news 2026/2/12 3:30:07

2025年3月GESP真题及题解(C++七级): 等价消除

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
2025年3月GESP真题及题解(C++七级): 等价消除

2025年3月GESP真题及题解(C++七级): 等价消除

题目描述

小 A 有一个仅包含小写英文字母的字符串S SS

对于一个字符串,如果能通过每次删去其中两个相同字符的方式,将这个字符串变为空串,那么称这个字符串是可以被等价消除的。

小 A 想知道S SS有多少子串是可以被等价消除的。

一个字符串S ′ S'SS SS的子串,当且仅当删去S SS的某个可以为空的前缀和某个可以为空的后缀之后,可以得到S ′ S'S

输入格式

第一行,一个正整数∣ S ∣ |S|S,表示字符串S SS的长度。

第二行,一个仅包含小写英文字母的字符串S SS

输出格式

一行,一个整数,表示答案。

输入输出样例 1
输入 1
7 aaaaabb
输出 1
9
输入输出样例 2
输入 2
9 babacabab
输出 2
2
说明/提示

对于20 % 20\%20%的测试点,保证S SS中仅包含a aab bb两种字符。

对于另外20 % 20\%20%的测试点,保证1 ≤ ∣ S ∣ ≤ 2000 1 \leq |S| \leq 20001S2000

对于所有测试点,保证1 ≤ ∣ S ∣ ≤ 2 × 10 5 1 \leq |S| \leq 2 \times 10^51S2×105

题目分析

核心思路

题目要求找出字符串S SS中所有可以被"等价消除"的子串。根据定义,一个字符串能被等价消除,当且仅当其中每个字符的出现次数都是偶数

因此,问题转化为:找出S SS中所有子串,使得每个字符的出现次数都是偶数。

关键观察
  1. 奇偶性状态压缩:因为只有小写字母(26种),可以用一个 26 位的二进制数表示每个字符出现次数的奇偶性(0表示偶数次,1表示奇数次)。

  2. 前缀异或思想

    • 定义prefix[i]表示前 i 个字符的奇偶性状态
    • 子串[l, r]的状态 =prefix[r] ^ prefix[l-1]
    • 子串满足条件 ⇔prefix[r] ^ prefix[l-1] = 0prefix[r] = prefix[l-1]
  3. 转化为计数问题:对于每个位置 r,统计有多少个 l (0 ≤ l < r) 使得prefix[l] = prefix[r]

  4. 高效实现:使用哈希表记录每个状态出现的次数。

算法步骤
  1. 初始化状态为 0,表示空字符串的奇偶性(所有字符出现0次,都是偶数)
  2. 遍历字符串的每个字符:
    • 更新当前奇偶性状态(异或对应字符的位)
    • 当前状态的出现次数 = 该状态之前出现的次数
    • 这些次数就是新增的满足条件的子串数量
    • 更新该状态的计数
  3. 累加所有满足条件的子串数量
时间复杂度
  • O(n),其中 n 是字符串长度
  • 使用哈希表实现状态计数的 O(1) 访问
空间复杂度
  • O(min(n, 2²⁶)),最多存储 n+1 个不同的状态

代码实现

#include<bits/stdc++.h>usingnamespacestd;intmain(){ios::sync_with_stdio(false);cin.tie(0);intn;string s;cin>>n>>s;// 状态压缩:用int的低26位表示26个字母的奇偶性intstate=0;// 当前前缀的奇偶性状态// 哈希表:记录每个状态出现的次数unordered_map<int,longlong>cnt;cnt[0]=1;// 空前缀的状态出现1次longlongans=0;// 结果可能很大,用long long// 遍历字符串for(charc:s){// 更新状态:异或对应字符的位intbit=c-'a';state^=(1<<bit);// 当前状态之前出现的次数 = 新增的满足条件的子串数ans+=cnt[state];// 更新该状态的计数cnt[state]++;}cout<<ans<<endl;return0;}

功能分析

核心功能
  1. 状态表示:使用整数的二进制位表示26个字母的奇偶性
  2. 前缀计算:通过异或运算高效更新状态
  3. 计数统计:使用哈希表记录状态出现次数
  4. 子串计数:通过状态匹配计算满足条件的子串数
正确性证明
  1. 必要性:如果子串能被等价消除,则每个字符出现偶数次,所以子串状态为0
  2. 充分性:如果子串状态为0,可以通过配对删除所有字符
  3. 计数正确prefix[r] = prefix[l]等价于子串[l+1, r]状态为0
示例分析

示例1:

输入:7 aaaaabb 处理过程: 位置0: state=0, cnt[0]=1, ans+=1 → ans=1, cnt[0]=2 位置1: state=1(a), cnt[1]=0, ans+=0 → ans=1, cnt[1]=1 位置2: state=0, cnt[0]=2, ans+=2 → ans=3, cnt[0]=3 位置3: state=1, cnt[1]=1, ans+=1 → ans=4, cnt[1]=2 位置4: state=0, cnt[0]=3, ans+=3 → ans=7, cnt[0]=4 位置5: state=3(a,b), cnt[3]=0, ans+=0 → ans=7, cnt[3]=1 位置6: state=1, cnt[1]=2, ans+=2 → ans=9, cnt[1]=3 输出:9

示例2:

输入:9 babacabab 处理过程类似,最终输出2

各种学习资料,助力大家一站式学习和提升!!!

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"########## 一站式掌握信奥赛知识! ##########";cout<<"############# 冲刺信奥赛拿奖! #############";cout<<"###### 课程购买后永久学习,不受限制! ######";return0;}

1、csp信奥赛高频考点知识详解及案例实践:

CSP信奥赛C++动态规划:
https://blog.csdn.net/weixin_66461496/category_13096895.html点击跳转

CSP信奥赛C++标准模板库STL:
https://blog.csdn.net/weixin_66461496/category_13108077.html 点击跳转

信奥赛C++提高组csp-s知识详解及案例实践:
https://blog.csdn.net/weixin_66461496/category_13113932.html

2、csp信奥赛冲刺一等奖有效刷题题解:

CSP信奥赛C++初赛及复赛高频考点真题解析(持续更新):https://blog.csdn.net/weixin_66461496/category_12808781.html 点击跳转

CSP信奥赛C++一等奖通关刷题题单及题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12673810.html 点击跳转

3、GESP C++考级真题题解:

GESP(C++ 一级+二级+三级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12858102.html 点击跳转

GESP(C++ 四级+五级+六级)真题题解(持续更新):https://blog.csdn.net/weixin_66461496/category_12869848.html 点击跳转


GESP(C++ 七级+八级)真题题解(持续更新):
https://blog.csdn.net/weixin_66461496/category_13117178.html

4、CSP信奥赛C++竞赛拿奖视频课:

https://edu.csdn.net/course/detail/40437 点击跳转

· 文末祝福 ·

#include<bits/stdc++.h>usingnamespacestd;intmain(){cout<<"跟着王老师一起学习信奥赛C++";cout<<" 成就更好的自己! ";cout<<" csp信奥赛一等奖属于你! ";return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/30 12:57:57

SGLang动态批处理:请求合并优化实战指南

SGLang动态批处理&#xff1a;请求合并优化实战指南 1. 引言 1.1 业务场景描述 在大模型推理服务部署过程中&#xff0c;随着用户请求数量的快速增长&#xff0c;系统吞吐量和响应延迟成为关键瓶颈。尤其是在多轮对话、任务规划、结构化数据生成等复杂场景下&#xff0c;传统…

作者头像 李华
网站建设 2026/2/10 12:37:33

PaddleOCR-VL与文心4.5对比:云端GPU双模型测试,1小时出报告

PaddleOCR-VL与文心4.5对比&#xff1a;云端GPU双模型测试&#xff0c;1小时出报告 你是不是也遇到过这样的场景&#xff1f;技术总监突然甩来一个任务&#xff1a;“我们想用OCR做文档解析&#xff0c;百度的PaddleOCR-VL和文心4.5哪个更强&#xff1f;明天给我一份对比报告。…

作者头像 李华
网站建设 2026/2/10 9:40:50

Z-Image-Turbo性能优化:提升推理速度的5个关键设置

Z-Image-Turbo性能优化&#xff1a;提升推理速度的5个关键设置 1. 背景与核心价值 随着文生图大模型在内容创作、设计辅助和AI艺术等领域的广泛应用&#xff0c;推理效率成为决定用户体验的关键指标。Z-Image-Turbo作为阿里达摩院基于DiT&#xff08;Diffusion Transformer&a…

作者头像 李华
网站建设 2026/2/9 21:52:43

开箱即用!DeepSeek-R1-Distill-Qwen-1.5B在树莓派上的实测体验

开箱即用&#xff01;DeepSeek-R1-Distill-Qwen-1.5B在树莓派上的实测体验 1. 引言&#xff1a;轻量级大模型的边缘部署新选择 随着大语言模型&#xff08;LLM&#xff09;能力的持续提升&#xff0c;如何在资源受限的设备上实现高效推理成为工程落地的关键挑战。传统千亿参数…

作者头像 李华
网站建设 2026/2/2 5:10:40

Qwen3-VL农业病虫害识别:1块钱快速测试田间照片

Qwen3-VL农业病虫害识别&#xff1a;1块钱快速测试田间照片 你是不是也遇到过这样的情况&#xff1f;农技站同事拿着手机拍的几张玉米叶照片&#xff0c;问你这是不是褐斑病。你看着那模糊的边缘和零星黄斑&#xff0c;心里没底——这到底是缺肥、晒伤&#xff0c;还是真菌感染…

作者头像 李华
网站建设 2026/2/9 16:10:47

GLM-TTS实战教程:短视频配音自动化流水线搭建

GLM-TTS实战教程&#xff1a;短视频配音自动化流水线搭建 1. 引言 随着短视频内容的爆发式增长&#xff0c;高效、个性化的语音合成需求日益迫切。传统配音方式依赖专业录音人员和后期制作&#xff0c;成本高、周期长&#xff0c;难以满足大规模内容生产的需求。GLM-TTS作为智…

作者头像 李华