解题思路:

 判断是否为回文,否就相加,因为无论是751还是157相加结果都一样,所以不用将结果转置求正确结果

注意事项:
十六进制时是ABCDEF要特殊处理
参考代码:

#include<iostream>

#include<algorithm>

#include<string>

#include<cstring>

#include<cstdio>

#include<vector>

using namespace std;


int n;

vector<int> add(vector<int> a){

    vector<int> b;

    int c=0;

    for(int i=a.size()-1;i>=0;i--){

        int re = (a[i]+a[a.size()-i-1]+c)%n;

        c=(a[i]+a[a.size()-i-1]+c)/n;

        b.push_back(re);

    }

    if(c)b.push_back(c);

    return b;

}


int panduan(vector<int> a){

    for(int i=0;i<a.size()/2;i++){

        if(a[i]!=a[a.size()-1-i])return 0;

    }

    return 1;

}

void solve(vector<int> a){

    for(int i=0;i<=30;i++){

        if(panduan(a)){

            cout<<"STEP="<<i<<endl;

            return;

        }

        a=add(a);

    }

    cout<<"Impossible!"<<endl;

}

int main(){

    cin>>n;

    vector<int> a;

    string m;

    cin>>m;

    //cout<<m;

    for(int i=0;i<m.length();i++){

        int x;

        if(m[i]>='0'&&m[i]<='9')x=m[i]-'0';

        else x=m[i]-'A'+10;

        a.push_back(x);

    }

    solve(a);

    return 0;

}


点赞(0)
 

0.0分

0 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论