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