news 2026/3/8 5:32:12

UVa 129 Krypton Factor

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
UVa 129 Krypton Factor

题目分析

本题要求生成“困难序列”,定义如下:
一个序列中如果存在两个相邻且相同的子串,则该序列为“简单序列”,否则为“困难序列”。
题目要求按字典序生成第nnn个困难序列,序列中的字符取自字母表前LLL个大写字母(1≤L≤261 \leq L \leq 261L26)。
输入以两个000结束。
输出时,序列每444个字符一组,组间用空格隔开;若组数超过161616,则从第171717组开始换行。
序列长度不超过808080

例如,当L=3L = 3L=3时,前777个困难序列为:

A AB ABA ABAC ABACA ABACAB ABACABA

解题思路

1. 核心问题:如何判断“困难序列”?

题目要求序列中不能包含两个相邻且相同的子串。
例如:ABACBCBADCB相邻重复出现,因此是简单序列。
我们需要一个高效的判断函数,对于任意序列,判断其是否合法。

一种直接的判断方法是:
设当前序列为sss,检查所有可能的子串长度jjj(从111⌊∣s∣2⌋\lfloor \frac{|s|}{2} \rfloor2s),
对于每个起始位置iii,比较s[i:i+j]s[i:i+j]s[i:i+j]s[i+j:i+2j]s[i+j:i+2j]s[i+j:i+2j]是否相同。
如果存在相同,则说明有相邻重复子串,序列不合法。

2. 生成字典序第nnn个困难序列

由于序列长度有限(最大808080),且字母表大小LLL不超过262626
我们可以使用**回溯法(DFS\texttt{DFS}DFS)**按字典序生成序列。

具体步骤:

  1. 从空串开始,每次尝试在当前串末尾添加一个字母(从字母表前LLL个字母中选择)。
  2. 每次添加后,调用判断函数检查新串是否合法(即是否为困难序列)。
  3. 如果合法,则继续向下递归;否则尝试下一个字母。
  4. 每次找到一个合法序列时,计数器加一。当计数器等于nnn时,输出当前序列并结束搜索。

剪枝优化

  • 当当前串不合法时,直接回溯,不继续扩展。
  • 每次尝试添加字母时,可以跳过那些显然会导致重复的字母(例如上一个字母相同的字母可以直接跳过,因为相邻相同字符会导致非法)。

3. 输出格式要求

  • 序列每444个字符一组,组间用空格隔开。
  • 如果组数超过161616组(即长度超过646464个字符),则从第656565个字符开始换行。
  • 输出序列后,在下一行输出序列长度。

4. 算法复杂度

  • 判断函数时间复杂度为O(∣s∣3)O(|s|^3)O(s3),但∣s∣≤80|s| \leq 80s80,可以接受。
  • 回溯搜索最坏情况下会尝试所有组合,但实际由于剪枝,效率较高。
  • 题目保证nnn不会超过可生成的困难序列总数,因此搜索不会无限进行。

代码实现

// Krypton Factor// UVa ID: 129// Verdict: Accepted// Submission Date: 2015-12-01// UVa Run Time: 0.000s//// 版权所有(C)2015,邱秋。metaphysis # yeah dot net#include<bits/stdc++.h>usingnamespacestd;boolisValid(string line){if(line.length()==1)returntrue;for(intj=1;j<=line.length()/2;j++)for(inti=0;i<line.length()-j;i++)if(line.substr(i,j)==line.substr(i+j,j))returnfalse;returntrue;}voiddisplay(string line){boolnewLinePrinted=false;for(inti=1;i<=line.length();i++){cout<<line[i-1];if(i%64==0){cout<<endl;newLinePrinted=true;}elseif(i%4==0&&i<line.length()){cout<<" ";newLinePrinted=false;}}if(newLinePrinted==false)cout<<endl;cout<<line.length()<<endl;}voidlexicographical(intn,intL){string alpha="ABCDEFGHIJKLMNOPQRSTUVWXYZ";string line="A";intcounter=1,start=0;while(counter<n){boolfound=false;for(inti=start;i<L;i++){if(alpha[i]==line[line.length()-1])continue;elseif(isValid(line+alpha[i])){found=true;start=0;counter++;line+=alpha[i];break;}}if(found==false){start=line[line.length()-1]-'A'+1;line.erase(line.length()-1,1);}}display(line);}intmain(intac,char*av[]){intn,L;while(cin>>n>>L,n||L)lexicographical(n,L);return0;}

总结

本题是一道经典的“困难序列”生成问题,通过回溯法和剪枝可以有效求解。关键点在于理解“相邻重复子串”的判断,以及如何按字典序生成序列。输出格式需要注意分组和换行的规则,避免格式错误导致无法通过。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/2 16:39:25

黑苹果小白福音:3步搞定OpenCore EFI配置,告别繁琐手动操作

黑苹果小白福音&#xff1a;3步搞定OpenCore EFI配置&#xff0c;告别繁琐手动操作 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 还在为黑苹果复杂的…

作者头像 李华
网站建设 2026/3/7 3:32:29

F3存储设备容量验证实用指南:快速识别假冒U盘与SD卡

F3存储设备容量验证实用指南&#xff1a;快速识别假冒U盘与SD卡 【免费下载链接】f3 F3 - Fight Flash Fraud 项目地址: https://gitcode.com/gh_mirrors/f3/f3 在数字化生活中&#xff0c;存储设备已成为我们不可或缺的数据伴侣。然而市场上虚标容量的假冒U盘和SD卡层出…

作者头像 李华
网站建设 2026/3/4 14:54:24

AI帮你解决VS Code双击无反应:智能诊断与修复方案

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个VS Code问题诊断工具&#xff0c;能够自动检测双击无反应的常见原因。功能包括&#xff1a;1. 检查系统环境变量和PATH设置 2. 扫描VS Code安装完整性 3. 检测冲突进程 4.…

作者头像 李华
网站建设 2026/2/27 2:13:06

智能仓储管理:CRNN OCR在物流标签识别的应用

智能仓储管理&#xff1a;CRNN OCR在物流标签识别的应用 引言&#xff1a;OCR技术如何重塑物流信息流 在智能仓储与自动化物流系统中&#xff0c;高效、准确地获取包裹上的文本信息是实现分拣、追踪和库存管理的核心前提。传统人工录入方式不仅效率低下&#xff0c;且极易出错…

作者头像 李华
网站建设 2026/2/28 9:12:49

好写作AI:当代大学生的“赛博导师”,论文破局就靠它了!

拯救论文的&#xff0c;不是奇迹&#xff0c;而是一个更懂学术的AI。“论文DDL&#xff08;截止日期&#xff09;还有三天&#xff0c;文档字数&#xff1a;200/8000。” 如果你对这句话感到血压上升&#xff0c;那么恭喜你&#xff0c;是亲大学生无疑了。曾经&#xff0c;我们…

作者头像 李华
网站建设 2026/3/1 5:40:51

iOS个性化神器Cowabunga:解锁iPhone深度定制新体验

iOS个性化神器Cowabunga&#xff1a;解锁iPhone深度定制新体验 【免费下载链接】Cowabunga iOS 14.0-15.7.1 & 16.0-16.1.2 MacDirtyCow ToolBox 项目地址: https://gitcode.com/gh_mirrors/co/Cowabunga 还在为千篇一律的iPhone界面感到厌倦吗&#xff1f;今天为你…

作者头像 李华