一、问题及代码
/*
* 文件名称:特殊三位数
* 作 者: 徐崇敏
* 完成日期: 2016年6 月 5 日
* 版 本 号:v1.0
* 对任务及求解方法的描述部分:
* 输入描述:
* 问题描述:请输出满足条件n=a!+b!+c!的所有三位数n,其中,a、b、c分别是n的百、十、个位数。要求用自定义函数实现求阶乘。
* 程序输出:
* 问题分析:
* 算法设计:
*/
#include<iostream>
using namespace std;
int fac(int n)
{
int p;
if(n==0)
p=1;
else
p=n*fac(n-1);
return p;
}
int main()
{
int a,b,c,a1,b1,c1,sum;
for(a=1;a<10;a++)
for(b=1;b<10;b++)
for(c=1;c<10;c++)
{
a1=fac(a);
b1=fac(b);
c1=fac(c);
sum=a1+b1+c1;
if(sum==100*a+10*b+c)
cout<<sum<<endl;
}
return 0;
}
二、运行结果
三、心得体会
此次实验中运用了递归函数,并不熟练,耗时较长,但经过多次的尝试终究把题目写出来了。
四、知识点总结
实验中运用了自调函数,较为灵活,可以用于阶乘函数中