请在UVA/SPOJ/atcoder/codeforces题库中查找原题,并给出c++代码以及思路:非混淆对话的兴奋水平是奶牛双重发送的次数,即S中子串BB或EE出现的次数。您想找到原始消息的兴奋水平,但您不知道哪些是Bessie / Elsie发送的Farmer John的消息。在所有可能性上,输出S的所有可能兴奋水平。

时间: 2023-05-24 14:06:36 浏览: 97
题目链接: UVA 12404 Excitement Levels SPOJ EXCITE - Excitement Levels Codeforces 583E - Watching Fireworks is Fun 题意概述: 有两只奶牛Bessie和Elsie通过一个电话线交换消息,每条消息可能是Bessie发出的、Elsie发出的,或两只奶牛都发出的。我们将Bessie和Elsie发出的消息的序列表示为两个字符串$B$和$E$,其中$B$表示Bessie发送的消息,$E$表示Elsie发送的消息。例如:当$B = \texttt{AEABBABA}$且$E = \texttt{BEABEAE}$时,下表描述了这两只奶牛之间的一些有可能的信息交换: $$ \begin{array}{|c|c|c|} \hline \textbf{位置} & \textbf{消息} & \textbf{发送方} \\ \hline 1 & A & B \\ \hline 2 & E & E \\ \hline 3 & A & E \\ \hline 4 & B & B \\ \hline 5 & A & E \\ \hline 6 & B & A \\ \hline 7 & A & B \\ \hline 8 & E & A \\ \hline 9 & - & - \\ \hline \end{array} $$ 对于给定的字符串$B$和$E$,我们可以尝试恢复出她们发送的所有消息。让$S$表示任意一种可能的恢复方案中,两只奶牛发送的所有消息组成的序列。例如:上表中的恢复方案为$\texttt{AEABBAEAB}$,其中有两个BB子串和两个EE子串。我们将$S$中BB子串和EE子串的总数称为这个方案的兴奋水平。 现在,给定$B$和$E$,请你计算出所有可能的兴奋水平,并把它们按从小到大的顺序输出。 题解: 一些定义: $B$的长度为$n$。 $E$的长度为$m$。 如果我们知道了一个恢复方案,那么我们可以在$O(n + m)$的时间内判断它的兴奋水平。具体来说,我们可以使用一个单调栈来计算所有在$S$中以BB或EE为结尾的子串的数量,其中栈中存储了在$S$中以B或E为结尾的子串的个数。 根据上面的定义,我们可以发现给定任意一个$S$,我们可以用单调栈在$O(n + m)$的时间内计算出$S$的兴奋水平,但是一个字符串有$n + m - 1$个位置,因此存在$(n + m - 1)!$多种可能的$S$。我们显然不能枚举所有的$S$。 解决方案: 我们可以直接计算出所有满足条件的$S$。具体来说,我们可以在一个递归的函数中,构建一个字符数组$S$,表示目前为止我们已经选择了哪些字符。在每个递归调用中,我们都会向$S$中添加一个字符——当前字符序列中次数较少的一个字符。如果$S$已经被填满,那么我们就可以在$O(n + m)$的时间内计算出当前方案的兴奋水平,并将其添加到答案数组中。这个递归函数的时间复杂度为$O((n + m)! (n + m))$,空间复杂度也为$O((n + m)!)$。在本题的数据范围内,这个算法可以通过本题。 代码:

相关推荐

洛谷的SPOJ需要注册一个SPOJ账号并进行绑定才能进行交题。您可以按照以下步骤进行注册: 1. 打开洛谷网站(https://www.luogu.com.cn/)并登录您的洛谷账号。 2. 在网站顶部导航栏中找到“题库”选项,将鼠标悬停在上面,然后选择“SPOJ”。 3. 在SPOJ页面上,您会看到一个提示,要求您注册SPOJ账号并进行绑定。点击提示中的链接,将会跳转到SPOJ注册页面。 4. 在SPOJ注册页面上,按照要求填写您的用户名、密码和邮箱等信息,并完成注册。 5. 注册完成后,返回洛谷网站,再次进入SPOJ页面。您会看到一个输入框,要求您输入刚刚注册的SPOJ用户名。输入用户名后,点击“绑定”按钮即可完成绑定。 现在您已经成功注册并绑定了SPOJ账号,可以开始在洛谷的SPOJ题库上刷题了。祝您顺利完成编程练习!\[1\]\[2\] #### 引用[.reference_title] - *1* *3* [(洛谷入门系列,适合洛谷新用户)洛谷功能全解](https://blog.csdn.net/rrc12345/article/details/122500057)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [luogu p7492 序列](https://blog.csdn.net/zhu_yin233/article/details/122051384)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

最新推荐

python图书管理系统、ui界面、qt,期末作业、毕业设计.zip

计算机类毕业设计源码

springboot流浪动物救助网站(vue)

这是一系列基于Spring Boot框架开发的项目,包括电商平台、学校管理系统、社交网站、图书馆管理系统、旅游规划系统等。这些项目采用现代化技术架构,具备良好的可扩展性和可维护性。 借助Spring Boot框架的功能和生态系统,这些项目实现了用户注册登录、数据管理、后台管理、在线交易、实时通信、数据分析等核心功能。同时,它们支持适应性布局,在不同设备上提供良好用户体验。 这些项目注重通用性和易用性,开发人员可以根据需求进行灵活定制和扩展。同时,提供丰富的文档和示例代码,以帮助开发人员快速上手。 总之,这些基于Spring Boot框架开发的项目广泛适用,旨在提供高效可靠的解决方案,帮助各行各业实现数字化转型和快速发展。

施耐德 5G+PLC 深度融合解决方案白皮书

工业互联网作为新一代信息技术与工业经济深度融合形成的新兴业态和应用模式,是工业 企业实现数字化转型的关键基础设施。5G 作为工业互联网网络的重要组成部分,在各个行业得到蓬勃发展。特别是过去三年,在国家 5G+工业互联网政策的鼓励下,十个工业行业和领域在制造业用户、基础电信运营商和通信企业的生态合作下,5G+工业互联网取得了很多成功案例并开始规模复制。目前 5G 网络开始向与工厂控制层面的 OT 网络深度融合方向拓展,并希望借此改变传统控制系统导致的网络拓扑结构固化及封闭的现状,以提高生产过程的柔性和透明性;通过5G 在工厂全覆盖,实现要素资源全连接,结合工业互联网平台、边缘计算、大数据和工业模型技术,从而大幅度地提高工程和运维效率,降低生产和建设成本。

基于核极限学习机KELM多维时间序列预测,KELM多变量时间序列预测,matlab代码 模型评价指标包括:R2、MAE、MS

基于核极限学习机KELM多维时间序列预测,KELM多变量时间序列预测,matlab代码。 模型评价指标包括:R2、MAE、MSE、RMSE和MAPE等,代码质量极高,方便学习和替换数据。

html5手机端动画展开收缩导航菜单特效.zip

有兴趣刚需的可以自己下载,非常实用的jquery代码,可以完美运行,有能力的还可以二次修改!

数据结构1800试题.pdf

你还在苦苦寻找数据结构的题目吗?这里刚刚上传了一份数据结构共1800道试题,轻松解决期末挂科的难题。不信?你下载看看,这里是纯题目,你下载了再来私信我答案。按数据结构教材分章节,每一章节都有选择题、或有判断题、填空题、算法设计题及应用题,题型丰富多样,共五种类型题目。本学期已过去一半,相信你数据结构叶已经学得差不多了,是时候拿题来练练手了,如果你考研,更需要这份1800道题来巩固自己的基础及攻克重点难点。现在下载,不早不晚,越往后拖,越到后面,你身边的人就越卷,甚至卷得达到你无法想象的程度。我也是曾经遇到过这样的人,学习,练题,就要趁现在,不然到时你都不知道要刷数据结构题好还是高数、工数、大英,或是算法题?学完理论要及时巩固知识内容才是王道!记住!!!下载了来要答案(v:zywcv1220)。

语义Web动态搜索引擎:解决语义Web端点和数据集更新困境

跟踪:PROFILES数据搜索:在网络上分析和搜索数据WWW 2018,2018年4月23日至27日,法国里昂1497语义Web检索与分析引擎Semih Yumusak†KTO Karatay大学,土耳其semih. karatay.edu.trAI 4 BDGmbH,瑞士s. ai4bd.comHalifeKodazSelcukUniversity科尼亚,土耳其hkodaz@selcuk.edu.tr安德烈亚斯·卡米拉里斯荷兰特文特大学utwente.nl计算机科学系a.kamilaris@www.example.com埃利夫·尤萨尔KTO KaratayUniversity科尼亚,土耳其elif. ogrenci.karatay.edu.tr土耳其安卡拉edogdu@cankaya.edu.tr埃尔多安·多杜·坎卡亚大学里扎·埃姆雷·阿拉斯KTO KaratayUniversity科尼亚,土耳其riza.emre.aras@ogrenci.karatay.edu.tr摘要语义Web促进了Web上的通用数据格式和交换协议,以实现系统和机器之间更好的互操作性。 虽然语义Web技术被用来语义注释数据和资源,更容易重用,这些数据源的特设发现仍然是一个悬 而 未 决 的 问 题 。 流 行 的 语 义 Web �

centos7安装nedit

### 回答1: 你可以按照以下步骤在 CentOS 7 上安装 nedit: 1. 打开终端并切换到 root 用户。 2. 运行以下命令安装 EPEL 存储库: ``` yum install epel-release ``` 3. 运行以下命令安装 nedit: ``` yum install nedit ``` 4. 安装完成后,你可以在终端中运行以下命令启动 nedit: ``` nedit ``` 如果你想打开一个文件,可以使用以下命令: ``` nedit /path/to/file

TFT屏幕-ILI9486数据手册带命令标签版.pdf

ILI9486手册 官方手册 ILI9486 is a 262,144-color single-chip SoC driver for a-Si TFT liquid crystal display with resolution of 320RGBx480 dots, comprising a 960-channel source driver, a 480-channel gate driver, 345,600bytes GRAM for graphic data of 320RGBx480 dots, and power supply circuit. The ILI9486 supports parallel CPU 8-/9-/16-/18-bit data bus interface and 3-/4-line serial peripheral interfaces (SPI). The ILI9486 is also compliant with RGB (16-/18-bit) data bus for video image display. For high speed serial interface, the ILI9486 also provides one data and clock lane and supports up to 500Mbps on MIPI DSI link. And also support MDDI interface.

数据搜索和分析

跟踪:PROFILES数据搜索:在网络上分析和搜索数据WWW 2018,2018年4月23日至27日,法国里昂1485表征数据集搜索查询艾米莉亚·卡普尔扎克英国南安普敦大学开放数据研究所emilia. theodi.org珍妮·坦尼森英国伦敦开放数据研究所jeni@theodi.org摘要在Web上生成和发布的数据量正在迅速增加,但在Web上搜索结构化数据仍然存在挑战。在本文中,我们探索数据集搜索分析查询专门为这项工作产生的通过众包-ING实验,并比较它们的搜索日志分析查询的数据门户网站。搜索环境的变化以及我们给人们的任务改变了生成的查询。 我们发现,在我们的实验中发出的查询比数据门户上的数据集的搜索查询要长得多。 它们还包含了七倍以上的地理空间和时间信息的提及,并且更有可能被结构化为问题。这些见解可用于根据数据集搜索的特定信息需求和特征关键词数据集搜索,�