解题思路:
注意事项:
参考代码:
#include<iostream>
#include<string.h>
using namespace std;
int main()
{
int n;
int sum=0,flag=0;//是回文数0,不是1
int ans=0;
//输入
cin>>n;
char s[7];
for(int i=99890;i<1000000;i++){
sum=0;
sprintf(s,"%d",i);
int l=strlen(s);
//找满足位数相加为n的数字
//循环判断两边的数是否相等,只要有一个不符合,输出-1
if(l%2==0){//偶数位数
for (int j = 0; j < l/ 2; j++) {
sum+=s[j]-48;
if (s[j] != s[l - j - 1]) {//if不满足
flag=1;
break;
}
else {
flag=0;
}
}
sum=2*sum;
if(flag==0&&sum==n){
cout<<i<<endl;
ans++;//ans不为0说明出现了满足条件的回文数
}
}
else{//奇数位数
for (int j = 0; j< l/ 2; j++) {
sum+=s[j]-48;//字符"0"ascll码是48,减去48就是数字0
if (s[j] != s[l - j - 1]) {//if不满足
flag=1;
break;
}
else {
flag=0;//是回文数
}
}
sum=2*sum+s[2]-48;
if(flag==0&&sum==n){
cout<<i<<endl;
ans++;//ans不为0说明出现了满足条件的回文数
}
}
}
if(ans==0){
cout<<-1<<endl;
}
return 0;
}
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:485 |
2005年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:652 |
母牛的故事 (C语言代码)浏览:946 |
1118(求助_已解决)浏览:329 |
Tom数 (C语言代码)浏览:496 |
2004年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:324 |
川哥的吩咐 (C语言代码)浏览:618 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:679 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:523 |
WU-C语言程序设计教程(第三版)课后习题12.3 (C++代码)浏览:864 |