当前位置: 首页 > news >正文

UVa 520 Append

题目描述

题目要求计算给定的编码序列CwC_wCw可以分解为CuCvC_u C_vCuCv的方式数,其中uuuvvv均为非空字符串,且w=uvw = uvw=uv。编码规则如下:

  • 每个编码对(pi,ri)(p_i, r_i)(pi,ri)要么是0 c(表示添加字符ccc),要么是p r(表示从当前位置往前ppp个位置开始,复制rrr个字符添加到末尾)。
  • 解码过程按顺序处理每个编码对,最终得到字符串www

需要统计将编码序列CwC_wCw拆分成两个非空前缀和后缀编码对序列的方式数,使得解码后的字符串恰好对应www的前缀和后缀。

输入格式

输入包含多个数据块。每个数据块由若干行组成,每行一个编码对:

  • pi=0p_i = 0pi=0,格式为0 c,其中ccc为小写字母。
  • pi>0p_i > 0pi>0,格式为p r,其中1≤r≤p<10001 \le r \le p < 10001rp<1000
    每个数据块后有一个空行。输入以文件结束符(EOF\texttt{EOF}EOF)终止。

输出格式

对于每个数据块,输出一行一个整数,表示分解方式的数目。

样例

输入

0 a 1 1 0 b 3 3 3 3 3 2 0 c

输出

1

题目分析

本题的核心是模拟解码过程,并确定所有可能的拆分点。

解码模拟

维护一个列表(或双端队列)记录每次添加操作后新字符的起始位置。每次解码时:

  • 若遇到0 c,则新字符的位置为当前字符串长度。
  • 若遇到p r,则新添加的字符是从当前位置往前ppp个位置开始的连续rrr个字符。这些字符对应的原始位置可以通过回溯得到。

拆分点计数

解码完成后,我们得到了整个字符串www的构建历史。每个字符都有一个“来源”位置(即它是由哪个编码对添加的)。CuC_uCu对应www的前缀部分,CvC_vCv对应后缀部分。CuC_uCu必须是某个前缀,且对应的编码对序列是CwC_wCw的某个前缀。关键是要找出所有位置kkk,使得前kkk个编码对解码出的字符串恰好是www的前缀,且后∣Cw∣−k|C_w| - kCwk个编码对解码出的字符串是www的后缀。

实际上,参考代码使用了一个队列cache来记录每次添加操作后新字符的索引。当遇到0 c时,将当前长度加入队列;当遇到p r时,通过回溯找到复制源的起始位置。最终队列中的元素个数减111即为分解方式数(因为最后一个元素对应整个字符串,而前面的每个元素都对应一个有效的拆分点)。

复杂度分析

每个编码对处理O(1)O(1)O(1)O(p)O(p)O(p),总复杂度可接受。

代码实现

// Append// UVa ID: 520// Verdict: Accepted// Submission Date: 2017-05-03// UVa Run Time: 0.000s//// 版权所有(C)2017,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;intmain(){cin.tie(0),cout.tie(0),ios::sync_with_stdio(false);intpi,ri;string line;while(getline(cin,line)){intcurrent=0;list<int>cache;do{pi=ri=0;intidx=0;while(!isblank(line[idx])){pi=pi*10+(line[idx]-'0');idx++;}if(pi==0)ri=1;else{idx++;while(idx<line.length()){ri=ri*10+(line[idx]-'0');idx++;}}if(pi==0)cache.push_back(current++);else{while(current-cache.back()<pi)cache.pop_back();current+=ri;}}while(getline(cin,line),line.length()>0);cout<<(cache.size()-1)<<'\n';}return0;}
http://www.jsqmd.com/news/1128981/

相关文章:

  • 【Linux】十一.进程概念--进程的控制
  • 2025年能量回馈的变流器负载试验装置(A题)的软件部分实现(全国大学生电子设计竞赛)
  • 小学期第四周记录
  • 存储芯片千问千答第4问:存储芯片中常说的E2E是啥?
  • 新e选烤火罩pH值[主里料](C类)GB/T 7573—2009 判定符合
  • 流放之路2构建规划终极指南:用Path of Building PoE2告别盲目配装
  • Python之rnaglib包语法、参数和实际应用案例
  • Evaluating Multimodal Large Language Models on Core Music Perception Tasks
  • 2026毕业生降AIGC平台盘点: 学术打磨+逻辑优化哪家强?
  • AI 全栈开发实战(15):全系列总结——从零到一做一个真正的 AI 产品
  • Explainability of Large Language Models: Opportunities and Challenges toward Generating Trustwort...
  • Web安全从入门到实战:一份430页的系统学习路线与CTF渗透指南
  • UVa 521 Gossiping
  • AI模型版本控制与A/B测试:优化模型性能的有效策略
  • 如何永久保存微信聊天记录?WeChatMsg的完整数据资产化方案
  • tf1exodus_037-1
  • 新e选烤火罩异味[主里料] GB 18401—2010 6.7 判定符合检测标准与测试条件
  • 【Ansible】(十四)流程控制与异常处理
  • 星露谷物语自动化革命:5大必备模组彻底改变你的农场生活 [特殊字符]
  • oyunfor土区礼品卡购买教程及踩坑记录
  • Python之ya-market-api包语法、参数和实际应用案例
  • 亚马逊证实对外销售自研 AI 芯片 Trainium,英伟达的垄断要被打破了吗?
  • 向量数据库选型与实战 —— Milvus、Qdrant、Chroma 深度对比与最佳实践
  • 置信区间构建:5 大常见误区与 R/Stata/SPSS 软件实操验证
  • opc.ua在NET6.0的使用
  • ProperTree:告别跨平台配置文件编辑困扰,用树形界面征服plist文件
  • 微调LLM提升工具调用能力的ShareGPT数据格式
  • 我的 AI 辅助开发工具链 2026 版——从 IDE 到 Agent,效率提升了多少?
  • 分布式事务解决方案全景:从 2PC 到 Saga,每种方案的适用场景与落地要点
  • AI 模型部署从入门到生产 —— ONNX 转换、TensorRT 加速、推理服务搭建