问题描述:编写程序,求某三位数,该数值的大小正好是组成这个数的三个位上的数字阶乘之和。
关于这道题主要考察嵌套循环结构
思路如下
设置一个三位数,然后依次求出其每一位上的数,然后再依次求出它们的阶乘结果最后使用if语句进行判断若有这么
#include<stdio.h>
int main()
{
int i = 0;
int a, b, c;
int sum1, sum2, sum3;
for ( i = 100; i <=999; i++)
{
a = i / 100;//百位数上的数字
b = i % 100 / 10;//十位数上的数字
c = i % 100 % 10;//个位数上的数字
sum1 = 1;sum2 = 1;sum3 = 1;
for ( a = a; a >1; a--)//此处因为是百位数,不能为零故a>1
{
sum1 *= a;
}
for (b = b; b > 0; b--)//此处为十位数上的数字可以为零,所以b>0
{
sum2 *= b;
}
for (c = c; c > 0; c--)
{
sum3 *= c;//此处与十位数的处理相同
}
if (sum1 + sum2 + sum3 == i)
{
printf("%d", i);
}
}
return 0;
}
一个三位数则用printf语句进行输出,代码如下