//话说我真的不是为了水文章,但是,dhu好像特别喜欢回文数这个素材,出了不知道多少题,和上一题就多了一个求各数位之和的函数
//当我用到函数提交的时候,手都在抖,生怕超时了
//有没有大佬提示一下如果没有回文数输出-1的方法,感觉我的这个有点笨拙了
AC代码:
#include<stdio.h>
#include<iostream>
using namespace std;
int reverse(int num)//数字逆序函数
{
int rev = 0;
while (num)
{
rev = 10 * rev + num % 10;
num /= 10;
}
return(rev);
}
int ispalin(int j)//判断是否是回文的函数
{
if (reverse(j) == j)
{
return(1);
}
return (0);
}
int sum(int x)//求各数位之和的函数
{
int sum = 0;
while (x)
{
sum += x % 10;
x /= 10;
}
return(sum);
};
int main()
{
//下测试sum函数是否正确
//cout << sum(12345);
int n=-1;//n的范围为10~100
cin >> n;
bool flag = false;
for (int i = 10000; i <= 999999; i++)
{
if (ispalin(i) == 1&&sum(i)==n)
{
cout << i << endl;
flag = true;
}
}
if (flag == false)
cout << "-1";
//system("pause");
return 0;
}