- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给定一个字符串"ababacba"
,我如何生成所有可能的回文子串?
我正在考虑以下方法:
但是,这似乎在某些情况下可能不起作用,例如它检测到 baba
为回文,而实际上它不是,因为读取 ababacba 与读一个babacba,两个粗体语句都有abab
及其反转的baba
。
因此,我认为这种方法是无效的,那么如何使用 trie 生成所有回文子串呢?
字符串 ababacba
的期望输出:
ababa
bab
aba
谢谢。
最佳答案
首先找出所有的子串,然后检查它们是否是回文。对于很长的字符串,此方法可能不会那么快。
def substrings(string, n):
result = []
for i in range(len(string)-n+1):
result.append(string[i:i+n])
return result
def all_substrings(string, min_n=2):
result = []
for n in range(min_n, len(string)):
result+=substrings(string, n)
return result
def is_palindrom(string):
return string == string[::-1] #[::-1] reverses string (look for slicing)
def sub_palindroms(string, min_n=2):
return [s for s in all_substrings(string, min_n=min_n) if is_palindrom(s)]
print(sub_palindroms('ababacba'))
关于algorithm - 如何用trie(或后缀trie)生成所有回文子串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58222693/
我正在尝试创建一个程序,其中字符串的前三个字符重复给定次数,如下所示: foo('Chocolate', 3) # => 'ChoChoCho' foo('Abc', 3) # => 'AbcAbcA
我有以下字符串: std::string str = "Mode:AAA:val:101:id:A1"; 我想分离一个位于 "val:" 和 ":id" 之间的子字符串,这是我的方法: std::st
DNA 字符串可以是任意长度,包含 5 个字母(A、T、G、C、N)的任意组合。 压缩包含 5 个字母(A、T、G、C、N)的 DNA 字母串的有效方法是什么?不是考虑每个字母表 3 位,我们可以使用
是否有一种使用 levenstein 距离将一个特定字符串与第二个较长字符串中的任何区域进行匹配的好方法? 例子: str1='aaaaa' str2='bbbbbbaabaabbbb' if str
使用 OAuth 并使用以下函数使用我们称为“foo”(实际上是 OAuth token )的字符串加密 key public function encrypt( $text ) { // a
我是一名优秀的程序员,十分优秀!