p1015 [NOIP1999 普及组] 回文数
[NOIP1999 普及组] 回文数
题目描述
若一个数(首位不为零)从左向右读与从右向左读都一样,我们就将其称之为回文数。
例如:给定一个十进制数
又如:对于十进制数
STEP1:
STEP2:
STEP3:
STEP4:
在这里的一步是指进行了一次
写一个程序,给定一个 Impossible!
。
输入格式
两行,分别是
输出格式
如果能在 STEP=ans
,其中
否则输出 Impossible!
。
样例 #1
样例输入 #1
10
87
样例输出 #1
STEP=4
思路
首先要考虑是否为回文数,所谓回文数就是将自己倒转和原来的相同。那么有一个函数reverse()完美符合我们的需求,它的作用就是将一个字符串倒转过来。那么我们可以写判断是否为回文数的func:
bool isdrome(string a){
string b=a;
reverse(b.begin(),b.end());
return a==b;
}
再回看题目,它需要将自己与自己的回文数加起来,由于我们处理的是字符串,因此我们需要把它转换成整型再进行相加,同时我们也要考虑相加后的进位问题:
string add(string a){
string b=a;
reverse(b.begin(),b.end());
int x,y,t=0,len=a.size();
for(int i=len-1;i>=0;i--){
x=(a[i]>='A')?(a[i]-'A'+10):(a[i]-'0');
y=(b[i]>='A')?(b[i]-'A'+10):(b[i]-'0');
x+=y+t;//此时是将x+y然后处理进位
t=(x>=n)?1:0;//进位判断
if(t==1){
x-=n;
}
a[i]=(x>9)?(x+'A'-10):(x+'0');//复原
}
if(t==1){
a="1"+a;
}
return a;
}
完整程序
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<map>
#include<vector>
#include<queue>
#include<set>
#include<unordered_map>
using namespace std;
int n;
string add(string a){
string b=a;
reverse(b.begin(),b.end());
int x,y,t=0,len=a.size();
for(int i=len-1;i>=0;i--){
x=(a[i]>='A')?(a[i]-'A'+10):(a[i]-'0');
y=(b[i]>='A')?(b[i]-'A'+10):(b[i]-'0');
x+=y+t;
t=(x>=n)?1:0;
if(t==1)
x-=n;
a[i]=(x>9)?(x+'A'-10):(x+'0');//复原
}
if(t==1)
a="1"+a;
return a;
}
bool isdrome(string a){
string b=a;
reverse(b.begin(),b.end());
return a==b;
}
int main(){
int i;
string m;
cin>>n>>m;
for(i=0;i<=30&&!isdrome(m);i++)
m=add(m);
if(i>30)
cout<<"Impossible!"<<endl;
else
cout<<"STEP="<<i<<endl;
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)