解题思路: 在main()函数里输入N,和循环查找,在AA()函数中判断是否为回文数字,在BB()函数中判断,某个数字的所有位的和,是否等于输入的数字N;设置一个计数变量看是否没有满足条件的,输出:-1 。
注意事项:
将数字转换为字符串方便检查是否为回文数字,也方便进行每位相加。
参考代码:
#include<bits/stdc++.h> using namespace std; bool AA(int a){ stringstream in; string b; in<<a; in>>b; for(int i=0;i<b.length()/2;i++){ if(b[i]!=b[b.length()-1-i]){ return 0; } } return 1; } bool BB(int x,int y){ stringstream in; string a; in<<x; in>>a; int sum=0; for(int i=0;i<a.length();i++){ sum=sum+a[i]-'0'; } if(sum==y){ return 1; } else return 0; } int main(){ int n; int count=0; cin>>n; for(int i=10000;i<=999999;i++){ if(AA(i)){ if(BB(i,n)){ cout<<i<<endl; count++; } } } if(count==0){ cout<<-1<<endl; } return 0; }
0.0分
6 人评分