解题思路:
判断是否为回文,否就相加,因为无论是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 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复