回文数c++

//回文数
#include<iostream>
#include<string>
using namespace std;
template<class T>
struct Node
{
 T data;
 Node<T> *next;
};
template<class T>
class linkstack
{
 Node<T> *top;
public:
 linkstack() { top = NULL; }
 ~linkstack();
 void push(T x);
 T pop();
 bool empty() { return top == NULL; }
};
template<class T>
linkstack<T>::~linkstack()
{
 Node<T> *p = top;
 while (p)
 {
  Node<T> *q;
  q = p;
  p = p->next;
  delete q;
 }
 top = NULL;
}
template<class T>
void linkstack<T>::push(T x)
{
 Node<T> *p = new Node<T>;
 p->data = x;
 p->next = top;
 top = p;
}
template<class T>
T linkstack<T>::pop()
{
 if (top == NULL)
 {
  cout << "下溢" << endl;
  exit(1);
 }
 T x;
 Node<T> *p = top;
 x = p->data;
 top = top->next;
 delete p;
 return x;
}
class palindrome
{
 char *str;
public:
 palindrome(char *a)
 {
  str = new char[strlen(a) + 1];
  strcpy(str, a);
 }
 bool palindromejudge();//判别
 void setstring(char *a);//重新设置字符串
 void output() { cout << str << endl; }//输出
};
bool palindrome::palindromejudge()
{
 linkstack<char> s;
 char *p = str;
 while (*p)
  s.push(*p++);
 p = str;
 while (!s.empty())
 {
  if (s.pop() != *p)
   return false;
  p++;
 }
 return true;
}
int main()
{
 char s[20];
 cout << "请输入待判别字符串:";
 cin.getline(s, 20);
 palindrome pa(s);
 if (pa.palindromejudge() == true)
  cout << "字符串" << s << "是回文!" << endl;
 else
  cout << "字符串" << s << "不是回文!" << endl;
 system("pause");
}

测试结果:
在这里插入图片描述

### 判断一个数是否为回文数C++实现 在C++中,判断一个数是否为回文数可以通过多种方法实现。以下是几种常见的实现方式及其详细说明。 #### 方法一:字符串比较法 此方法将整数转换为字符串,并通过双指针技术从两端向中间逐步比较字符是否相等。如果所有对应位置的字符均相等,则该数为回文数[^3]。 ```cpp #include <iostream> #include <string> using namespace std; bool isPalindrome(int x) { if (x < 0) { return false; // 负数不是回文数 } string s = to_string(x); int left = 0; int right = s.length() - 1; while (left < right) { if (s[left] != s[right]) { return false; // 如果左右字符不相等,则不是回文数 } left++; right--; } return true; // 所有字符均相等,则是回文数 } int main() { int num; cout << "Enter a number: "; cin >> num; if (isPalindrome(num)) { cout << num << " is a palindrome number." << endl; } else { cout << num << " is not a palindrome number." << endl; } return 0; } ``` #### 方法二:数字反转法 此方法通过将整数反转并与原数进行比较来判断是否为回文数。如果反转后的数字与原数字相等,则该数为回文数[^2]。 ```cpp #include <iostream> using namespace std; bool isPalindrome(int x) { if (x < 0) { return false; // 负数不是回文数 } int original = x; int reversed = 0; while (x > 0) { reversed = reversed * 10 + x % 10; // 反转数字 x /= 10; } return original == reversed; // 比较原数与反转后的数 } int main() { int num; cout << "Enter a number: "; cin >> num; if (isPalindrome(num)) { cout << num << " is a palindrome number." << endl; } else { cout << num << " is not a palindrome number." << endl; } return 0; } ``` #### 方法三:部分反转法 此方法仅反转数字的一半,并将其与另一半进行比较。这种方法可以减少不必要的计算,提高效率[^4]。 ```cpp #include <iostream> using namespace std; bool isPalindrome(int x) { if (x < 0 || (x % 10 == 0 && x != 0)) { return false; // 负数或末尾为0的非零数不是回文数 } int reversedHalf = 0; while (x > reversedHalf) { reversedHalf = reversedHalf * 10 + x % 10; // 反转一半数字 x /= 10; } return x == reversedHalf || x == reversedHalf / 10; // 比较原数的一半与反转后的一半 } int main() { int num; cout << "Enter a number: "; cin >> num; if (isPalindrome(num)) { cout << num << " is a palindrome number." << endl; } else { cout << num << " is not a palindrome number." << endl; } return 0; } ``` ### 总结 以上三种方法均可用于判断一个数是否为回文数。字符串比较法简单易懂,但涉及类型转换;数字反转法直接操作数字,逻辑清晰;部分反转法则更高效,适合处理大数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值