判断字符串是否为回文栈
时间: 2023-10-16 20:11:52 浏览: 160
判断字符串是否为回文可以使用栈这种数据结构来实现。具体的实现步骤如下:
1. 首先,创建一个空栈。
2. 将字符串的前一半字符依次入栈,如果字符串长度为奇数,则忽略中间的字符。
3. 遍历字符串的后一半字符,同时将栈顶字符出栈并与当前字符比较。
4. 如果所有字符都相同,则字符串为回文;如果有任何一个字符不相同,则字符串不是回文。
以下是一个示例的C++代码:
```
#include <iostream>
#include <stack>
using namespace std;
bool isPalindrome(string s) {
stack<char> stk;
int n = s.length();
// 将字符串前一半字符入栈
for (int i = 0; i < n / 2; i++) {
stk.push(s[i]);
}
// 遍历字符串后一半字符并与栈顶字符比较
int i = (n % 2 == 0) ? n / 2 : n / 2 + 1;
while (i < n) {
if (s[i] != stk.top()) {
return false;
}
stk.pop();
i++;
}
return true;
}
int main() {
string str;
cout << "请输入一个字符串:";
cin >> str;
if (isPalindrome(str)) {
cout << "该字符串是回文。" << endl;
} else {
cout << "该字符串不是回文。" << endl;
}
return 0;
}
```
阅读全文