#include <iostream>
#include <string>
using namespace std;
// 流程:输入--判断回文(是则输出)---否:倒叙相加--判断回文--倒叙相加--判断回文.……
string add(string a, string b)//把两个字符串相加
{
int up = 0, sum; //up储存进位
string c;
for (int i = a.size() - 1; i >= 0; i--) { //从末尾开始相加
sum = a[i] - '0' + b[i] - '0' + up;
up = sum / 10;
sum %= 10;
c = (char)(sum + '0') + c; //注意顺序有区别,如果c在前输出的是反序,需要再颠倒一次顺序
}
if (up > 0)
c = (char)(up + '0') + c;
return c;
}
int judge(string m) { //判断回文
for (int i = 0; i <= m.length() / 2; i++) {
if (m[i] != m[m.length() - 1 - i])
return 0;
}
return 1;//是回文
}
int main()
{
string m;
cin >> m;
string a, b;
for (int i = 0; i<10; i++) {
//注意:1、有可能第一次输入就为回文,所以判断语句应该在前面。
if (judge(m)) {
cout << m << " is a palindromic number." << endl;
return 0;
}
a = m;
b = m.assign(m.rbegin(), m.rend());//赋值
//c.rbegin() 返回一个逆序迭代器,它指向容器c的最后一个元素
//c.rend() 返回一个逆序迭代器,它指向容器c的第一个元素前面的位置
m = add(a,b);
cout << a << " + " << b << " = " << m << endl;
}
cout << "Not found in 10 iterations.";
return 0;
}
*PAT1079 延迟的回文数 (20 分)
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 【蝴蝶效应】 蝴蝶效应:上个世纪70年代,美国一个名叫洛伦兹的气象学家在解释空气系统理论时说,亚马逊雨林一只蝴蝶...
- 我的PAT系列文章更新重心已移至Github,欢迎来看PAT题解的小伙伴请到Github Pages浏览最新内容。...
- 题目 给定一个 k+1 位的正整数 N,写成 ak⋯a1a0 的形式,其中对所有 i 有 0≤a...