题解:AT_agc027_e [AGC027E] ABBreviate

news/2025/9/22 15:45:30/文章来源:https://www.cnblogs.com/LUlululu1616/p/19105408

题意:很简单了,不再赘述。

做法:

我们先考虑最后的串会被更新成什么样子,发现应该是一段区间会缩起来成为一个字符,那么我们考虑一段怎么样的区间会变成 ab

我们考虑一个能缩的区间会缩成什么或者不能缩,首先从 a,b 的个数上考虑,要不然是 \(+2,-1\) 要不然是 \(-1,+2\),所以我们模 \(3\),考虑给 \(a\) 赋权为 \(1\)\(b\) 赋权为 \(2\),那么一段区间缩成什么取决于区间和,当然为 \(0\) 就说明这个区间没救了缩不了。这是一个必要条件。

那么上面这个东西的 bug 在哪里呢?我们手玩一下发现问题好像只有在 abababa... 这样交替的会出问题,那么我们就考虑再加一个条件也就是要求一定要有相邻两个元素相等。

接下来我们来说明一下,考虑归纳,那么我们只需要说明对于一个有相邻元素相等的串,他可以缩成一个长度更小且有相邻相同的串,这个非常好说明,我们拉出来那一对位置,假设是 aa,考虑他们的两端,如果有 b 那么直接缩证明完了,否则就是 ...aaaa... 状物,那么直接缩两次就可以了。

那么我们考虑怎么计数,如果我们现在有一个串 \(s\),我们要判定能不能缩成 \(t\),该如何判断。

首先他们赋值后模 \(3\) 肯定是要相同的,然后我们发现一件事情,我们其实可以对于 \(t\) 从前往后贪心地用 \(s\) 中的一段去匹配 \(t\) 中的字符。因为最后剩出来的那一段一定模 \(3\)\(0\),所以我们可以直接划到最后一个字符里去。

那么我们可以设一个 dp,\(dp_i\) 代表用后缀 \(s_{i\cdots n}\) 能缩出来哪些串,假设我们能快速算出来 \(nxt_{i,0},nxt_{i,1}\),这里 \(nxt_{i,0/1}\) 代表从 \([i,nxt_{i,0/1}]\) 可以缩成 a/b 并且长度最小,那么我们的转移式就是 \(dp_i = dp_{nxt_{i,0}} + dp_{nxt_{i,1}}+[s_{i\cdots n} 和为 \ 0]\),这里加上最后这个东西是为了方便往前加整段,当然注意这样对于 \(1\cdots n\) 整个权值为 \(0\) 的情况多算一个空串,要减掉。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/909517.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【PostgreSQL 17】11 窗口函数

直接这么写会报错,缺少GROUP BY SELECTemployee_id,first_name,last_name,salary,AVG(salary) FROM employees ;添加OVER() SELECTemployee_id,first_name,last_name,salary,AVG(salary) OVER() FROM employees ;定义…

网站添加链接如何创建微信公众号要钱吗

Threejs文字与css2d/css3d技术 学习ThreeJS的捷径学习之前先搞清楚自己想要什么样的效果贴图文字准备一张带文字的png贴图使用sprite来进行贴图实现2D始终面朝相机的文字使用planeGeometry来贴图实现3D文字使用planeGeometry来贴图实现伪3D文字动态贴图文字html2Canvas 文字几何…

网络公司品牌推广哈尔滨网站优化对策

下面是我翻译的关于帮助理解抽象类的例子。 这是一个例子帮助我们理解抽象类。在我看来这是一个非常简单的方法。让我们一起来看看下面的代码&#xff1a; <?php class Fruit { private $color; public function eat() { //chew } publi…

百度右侧相关网站西安做网站的公司哪家好

在Spring Cloud中&#xff0c;Gateway可以通过配置文件来实现负载均衡。以下是一个简单的配置示例&#xff0c;它演示了如何将请求代理到名为service-instance的服务的两个不同实例。 spring:cloud:gateway:routes:- id: service-instance-routeuri: lb://service-instancepre…

一级A做爰片安全网站长春关键词优化平台

展开全部步骤&#xff1a;1、设计总体中的N个个体编号。2、把号码写在号e68a84e8a2ad3231313335323631343130323136353331333431366366签上&#xff0c;将号签放在一个容器中搅拌均匀。3、每次从中抽取一个号签&#xff0c;连续不放回抽取n次。4、将取出的n个号签上所对应的n个…

做网站php与python商城网站建设目标

我们使用传统的Process.Start(".exe")启动进程会遇到无法打开UI界面的问题&#xff0c;尤其是我们需要进行开启自启动程序设置时出现诸多问题&#xff0c;于是我们就想到采用windows服务开机自启动来创建启动一个新的exe程序&#xff0c;并且是显式运行。 首先是打开…

wordpress 二级域名谷歌广告优化师

文章目录 一、 pom.xml依赖包二、yml配置文件三、消费者四、生产者总结 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 一、 pom.xml依赖包 <dependency><groupId>org.springframework.kafka</groupId><artifactId>spring-kafka<…

网站建设情况总结wordpress如何绑定域名

【关键字】 服务卡片、卡片跳转不同页面、卡片跳转页面携带参数 【写在前面】 本篇文章主要介绍开发服务卡片时&#xff0c;如何实现卡片点击跳转不同页面&#xff0c;并携带动态参数到js页面。在此篇文章“服务卡片 API6 JSUI跳转不同页面”中说明了如果跳转不同页面&#xf…

商家列表管理与公众号二维码绑定​,方便对用户进行消息通知提醒

gofly.v1kf.com vx: llike620 ​ ​​一、 核心业务流程​​​​管理员登录​​:管理员通过后台系统登录验证。​​查看商家列表​​:进入“商家管理”模块,以列表形式查看所有已注册的商家信息。​​生成绑定二维…

linux权限细化管理的三种方法:polkit sudoer doas做权限管理

场景 1:允许普通用户挂载外部USB驱动器 这个场景完美体现了从“命令控制”到“动作控制”的范式转变。 1. 使用 sudo / doas 实现(传统方式) 思路: 找到挂载命令(mount, udisksctl),授权用户执行它。sudo 配置 …

国产化Excel开发组件Spire.XLS教程:Python 写入 Excel 文件,数据写入自动化实用指南

Excel 是最常用的数据整理、分析和展示工具之一。在本文中,我们将介绍如何借助Spire.XLS使用 Python 将数据写入 Excel 文件,内容涵盖结构化数据插入、格式设置以及数据导出。文中示例所用库支持在代码中直接创建并自…

Ansible的安装和使用

一、安装 #安装源 # 1.安装 yum install epel-release -y yum install ansible -y# 2.生成公钥 [root@vm01 ~]# ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/…

运城做网站推广网站的文案

今天安装软件&#xff0c;突然遇到了文件已损坏&#xff0c;扔到废纸篓的情况&#xff0c;于是搜索了下解决办法&#xff0c;跟大家分享下&#xff0c;希望对你有所帮助 一、检查安全性设置 打开【设置】-【隐私与安全】&#xff0c;下拉找到安全性&#xff0c;将安全性更改为…

晋城客运东站网站开发什么nas可以做网站服务器

提供侧边栏可以显示和隐藏的侧边栏容器&#xff0c;通过子组件定义侧边栏和内容区&#xff0c;第一个子组件表示侧边栏&#xff0c;第二个子组件表示内容区。 说明&#xff1a; 该组件从API Version 8开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起…

网站建设培训哪里好网站建设与搜索引擎营销的关系

通常各种编程语言里&#xff0c;都有对应的各种线性代数库&#xff0c;我们可以利用现成的代数库来快速的求解我们想要的结果&#xff0c;也就是说&#xff0c;通过代数库&#xff0c;会让我们可以用更少的代码&#xff0c;更高的效率实现需求&#xff0c;这就是向量化的作用 …

政协机关网站建设wordpress在php什么版本号

BeanPostProcessor 接口是 Spring 框架中的一个扩展接口&#xff0c;用于在 Spring 容器实例化、配置和初始化 bean 的过程中提供自定义的扩展点。通过实现这个接口&#xff0c;您可以在 bean 实例创建的不同生命周期阶段插入自己的逻辑&#xff0c;从而实现对 bean 行为的定制…

网站建设中需求分析说明书国内平面设计公司

纠错码和压缩算法是同一枚硬币的两面。 两者都来自于对冗余的想法。 纠错码被视为向消息或文件中添加冗余的原则性方法。而压缩算法正好相反&#xff0c;他们会从消息或文件中移除冗余。 压缩和纠错并不是彼此抵消的&#xff0c;相反&#xff0c;好的压缩算法会移除抵消冗余&am…

wordpress网站被拒登郑州app拉新项目

能控性定义&#xff1a; 若给定系统的一个初始状态x(t0)&#xff08;t0可为0&#xff09;&#xff0c;若在t1>t0的有限时间区间[t0,t1]内&#xff0c;存在容许控制u(t)使得x(t1)0&#xff0c;则称系统状态在t0时刻是能控的。 若系统对任意一个初始状态都能控&#xff0c;则…

北京网站设计公司哪家公司好广告营销包括哪些方面

服务器同时连接数突然变高的原因 在服务器运行过程中&#xff0c;我们有时会发现服务器的同时连接数突然变高。这种情况可能会引发一系列问题&#xff0c;如性能下降、资源耗尽等。那么&#xff0c;导致服务器同时连接数突然变高的原因有哪些呢&#xff1f;本文将对此进行探讨…

做设计参考的网站抖音代运营协议

设计模式 创建者模式 前言原来代码使用设计模式总结Builder模式在源码中的应用&#xff1a;其他代码 前言 “对象创建”模式——绕开new 工厂模式 抽象工厂 原型模式 构建器 动机与背景 目前需要建造一个房子&#xff0c;建造房子需要一系列特定的步骤&#xff0c;但是房子的类…