解题思路:两个函数:1.求各位数之和;2.判断是否为回文数字。
注意事项:可用sprintf()把数字转化为字符串方便操作。
参考代码:
// [蓝桥杯][历届试题]回文数字
#include <stdio.h>
#include <string.h>
// 求各位数之和
int sum(int n)
{
int result = 0;
char s[10];
sprintf(s, "%d", n);
for (int i = 0; i < strlen(s); i++)
{
result += s[i] - '0';
}
return result;
}
// 判断是否为回文数字
int fun(int n)
{
char s[10];
sprintf(s, "%d", n);
int len = strlen(s), flag = 0; //字符串长度,判断标志
if (len == 5) //五位数字
{
if ((s[0] == s[4]) && (s[1] == s[3]))
flag = 1;
}
else
{
if ((s[0] == s[5]) && (s[1] == s[4]) && (s[2] == s[3]))
flag = 1;
}
return flag;
}
int main()
{
int n, count = 0;
scanf("%d", &n);
for (int i = 10000; i <= 999999; i++)
{
if (fun(i) && (sum(i) == n)) //是回文数字
{
printf("%d\n", i);
count++;
}
}
if(count==0)//没有回文数字
printf("-1");
return 0;
}
0.0分
1 人评分
C语言训练-计算1~N之间所有奇数之和 (C语言代码)浏览:650 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:637 |
C语言程序设计教程(第三版)课后习题6.9 (C语言代码)浏览:772 |
兰顿蚂蚁 (C++代码)浏览:1044 |
求组合数 (C语言代码)浏览:1154 |
wu-淘淘的名单 (C++代码)浏览:1337 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:537 |
矩阵加法 (C语言代码)浏览:1722 |
字符逆序 (C语言代码)浏览:460 |
剪刀石头布 (C++代码)浏览:1709 |