11得票2回答
使用Coq证明可逆列表是回文。

这是我关于回文的归纳定义:Inductive pal { X : Type } : list X -> Prop := | pal0 : pal [] | pal1 : forall ( x : X ), pal [x] | pal2 : forall ( x : X ) (...

10得票10回答
Python中的递归函数回文字符串

我需要帮助编写一个递归函数,用于检测一个字符串是否为回文。但是我不能使用任何循环而必须使用递归。有人能帮助我展示如何实现吗?我正在使用Python。

10得票3回答
使用正则表达式查找回文字符串

这个问题是为了理解一个回答而提出的:如何使用正则表达式检查字符串是否为回文? Markus Jarderot 给出的答案是:/^((.)(?1)\2|.?)$/ 有人能解释一下,这里到底发生了什么...我需要在Perl中做类似的事情,但是无法理解这个解决方案!!! 附注:我不太擅长Perl...

10得票5回答
将字符串转换为回文字符串的最小插入次数

为了找到将给定字符串(s)转换为回文所需的最小插入次数,我找到该字符串(lcs_string)及其反转字符串的最长公共子序列。因此,需要进行的插入次数为 length(s) - length(lcs_string)。 知道需要进行的插入次数后,应采用什么方法来找到等效的回文字符串? 例如:...

9得票2回答
检查列表是否为回文。如果不是,则插入元素使其成为回文。(Prolog)

我已经编写了以下代码来检查它是否是回文。当列表不是回文时,我还创建了插入元素的逻辑。 reverse_list(Inputlist, Outputlist) :- reverse(Inputlist, [], Outputlist). reverse([], Outputli...

9得票8回答
如何检测回文的第一次出现

假设您正在从字符流中读取,当您读取第一个回文出现时,函数应该返回。 回文的长度应为偶数。 时间复杂度要求为O(N)。 示例: 1. 第一个字符:4 2. 第二个字符:1 3. 第三个字符:3 4. 第四个字符:3 5. 第五个字符:1 6. 第六个字符:4,返回结果。

9得票8回答
检查回文数的奇偶性?

检查回文数/字符串的奇偶长度是否是个好主意?大多数我找到的片段都没有执行这个基本测试。如果长度是偶数,它不能是回文吧? if len(var) % 2 != 0: # could be a palindrome, continue... else: break 还是直接比较第一个...

9得票4回答
寻找最长回文子串的解决方案之一难以理解。

请参考这篇关于leetcode的文章,解决最长回文子串问题时有一个常见错误: 将 S 反转成 S',找到 S 和 S' 之间的最长公共子串,这也必须是最长回文子串。 例如: S = “abacdfgdcaba”,S’ = “abacdgfdcaba”。 S 和 S' 之间的最长公共子串...

9得票9回答
使用Scala编写回文数

我遇到了这个CodeChef上的问题。问题陈述如下: 正整数如果在十进制下从左往右读和从右往左读相同,则称其为回文数。给定一个不超过1000000位的正整数K,编写代码输出大于K的最小回文数。 我可以定义一个isPalindrome方法如下: def isPalindrome(someN...

9得票1回答
在O(n)或O(n log n)的时间复杂度下找到回文子串的数量?

我知道你可以使用马拉车算法在O(n)时间内找到最长回文子串,但是是否有可能在O(n)或O(n log n)的时间内找到回文子串的总数呢?如果可以,你会如何实现? 也将单个字母视为回文字符串。 例如,"xyxyx"的回文子串数量为9。 这是因为你有: 5 single letter pa...