收藏 分享(赏)

ACM试题1159 回文词.ppt

上传人:gnk289057 文档编号:7925135 上传时间:2019-05-30 格式:PPT 页数:11 大小:78KB
下载 相关 举报
ACM试题1159 回文词.ppt_第1页
第1页 / 共11页
ACM试题1159 回文词.ppt_第2页
第2页 / 共11页
ACM试题1159 回文词.ppt_第3页
第3页 / 共11页
ACM试题1159 回文词.ppt_第4页
第4页 / 共11页
ACM试题1159 回文词.ppt_第5页
第5页 / 共11页
点击查看更多>>
资源描述

1、1159 回文词,报告人:李鑫,问题描述:,回文词是一种对称的字符串。任意给定一个字符串,通过插入若干字符,都可以变成回文词。次题的任务是,求出将给定字符串变成回文词所需要插入的最少字符数。,示例:,比如 “Ab3bd”插入2个字符后可以变成回文词“dAb3bAd”或“Adb3bdA”,但是插入少于2个的字符无法变成回文词。 注:此问题区分大小写,数学描述:,对于一个串S=a1a2an,求最小的m,使得存在一个串S=b1b2bm+n满足S为S的一个子串(可不连续),并且bi=bm+n-i+1(i=1m+n)。,分析:,设S 各个字符中不为S中字符的字符位置集为X 。故是不可能同时成立的。所以可

2、以把S中的字符分成两类A,B:A:S中与此字符对称的字符出现在S-S中B:S中与此字符对称的字符出现在S中,比如把Ab3bd扩充成 d A b 3 b A d(红色的字母是添加的) 1 2 3 4 5 6 7 位置2,7的对称位置的字符不属于S, 故A=2, 7 位置3,4,5的对称位置的字符属于S, 故B=3, 4, 5,分析续:,有以下结论: |A|+|B|=|S|=n |A|=|X| B是回文词且B是S的子串 |X|=|A|=n-|B|,问题转化为求S的最大回文子串B。,算法设计:,已知S=a1a2an 设T=c1c2cn =ana2 a1 设L(i,j)表示a1a2ai和c1c2cj的最长公共子序列的长度。 则有下面的结论:,算法设计:,max|B|= max 2*max(L(i,n-i), 2*max(L(i,n-1-i)+1 其中L(i,j)可以用如下递推公式得到:,更容易想到的算法:,令c (i,j)表示将子串aiai+1aj变成回文词的最小添加字符数。则这此问题就是要求c(1,n)。 c(i,j)满足如下递推关系:,以上两种算法的复杂度,空间复杂度O(n) 时间复杂度O(n2),Thank you!,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报