回文是指正读和反读均相同的字符序列,如”abba”和”abdba”均是回文,但”good”不是回文,试写一算法利用栈判定给定的字符序列是否为回文。(提示:将一半字符入栈)
时间: 2023-10-30 22:15:21 浏览: 82
算法思路:
首先将字符序列的一半依次入栈,然后依次取出栈中的字符与字符序列的另一半进行比较,如果相同则继续比较,如果不同则说明不是回文。
算法实现:
1. 初始化栈;
2. 将字符序列的一半依次入栈;
3. 依次取出栈中的字符与字符序列的另一半进行比较,如果相同则继续比较,如果不同则说明不是回文;
4. 如果全部比较完毕,都相同,则说明是回文。
代码实现:
```python
def is_palindrome(s):
stack = []
n = len(s)
for i in range(n//2):
stack.append(s[i])
for i in range(n//2, n):
if stack.pop() != s[i]:
return False
return True
```
测试样例:
```python
print(is_palindrome('abba')) # True
print(is_palindrome('abdba')) # True
print(is_palindrome('good')) # False
```
相关问题
回文是指正读、反读均相同的字符序列,如"abba"和“abdba”均是回文。“good”不是回文。试设计算法判定给定的字符序列是否是回文
一个简单的判断回文的算法如下:
1. 从字符串的两端分别开始遍历,判断每个字符是否相等。
2. 如果在遍历过程中发现任何不相等的字符,就说明这个字符串不是回文。
3. 当左右两端的遍历相遇时,就说明这个字符串是回文。
下面是算法的Python代码实现:
```python
def isPalindrome(s):
i, j = 0, len(s) - 1
while i < j:
if s[i] != s[j]:
return False
i += 1
j -= 1
return True
```
这个算法的时间复杂度是$O(n)$,其中$n$是字符串的长度。
回文是指正读和反读均相同的字符序列,如“abba”和“abdba”均是回文,但“good”不是回文。试写一个算法判定给定的字符串是否为回文。
算法如下:
1. 定义两个指针,一个指向字符串的开头,一个指向字符串的结尾。
2. 每次比较两个指针指向的字符是否相同,如果不同,则不是回文。
3. 如果相同,则将两个指针向中间移动,继续比较。
4. 当两个指针相遇时,说明字符串是回文。
代码实现:
```
bool isPalindrome(string s) {
int left = , right = s.length() - 1;
while (left < right) {
if (s[left] != s[right]) {
return false;
}
left++;
right--;
}
return true;
}
```
阅读全文
相关推荐













