原题链接:回文数(二)
解题思路:
参考代码:
#include <stdio.h> #include <string.h> int ishw(char *m) { int len=strlen(m); int i=0,j=len-1,flag=1; while(i<=j) { if(m[i]!=m[j]) { flag=0;break; } i++; j--; } return flag; } void getReverse(char *m,char *re_m) { int len=strlen(m); int i=len-1,j=0; for(;i>=0;i--,j++) { re_m[j]=m[i]; } re_m[j]='\0'; } void addToM(int n,char *m,char *re_m) { int i=0,j; int a[20]; memset(a,0,sizeof(a)); while(m[i]!='\0') { if(m[i]>='A'&&m[i]<='Z') a[i]+=(int)((m[i]-'A')+10); else a[i]+=(m[i]-'0'); if(re_m[i]>='A'&&re_m[i]<='Z') a[i]+=(int)((re_m[i]-'A')+10); else a[i]+=(re_m[i]-'0'); i++; } j=0; while(j<i) { a[j+1]+=(a[j]/n); if(n<=10) {m[j]=a[j]%n+'0';} else{ if((a[j]%n)>=10) m[j]='A'+(a[j]%n-10); else m[j]=a[j]%n+'0'; } j++; } if(a[j]>=10) {m[j]=(a[j]-10)+'A';m[j+1]='\0';} else if(a[j]>0) {m[j]=a[j]+'0';m[j+1]='\0';} else m[j]='\0'; } int main() { int n,cnt=0; char m[100],re_m[100]; scanf("%d",&n); scanf("%s",m); while(!ishw(m)&&cnt<=30) { getReverse(m,re_m); addToM(n,m,re_m); cnt++; } if(!ishw(m)) printf("Impossible"); else printf("STEP=%d",cnt); return 0; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复