解题思路:

参考代码:

#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分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论