问题及代码
/*
* Copyright (c) 2014, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:辛彬
* 完成日期:2014年 11 月 6 日
* 版 本 号:v1.0
*
* 问题描述:求满足条件n=a!+b!+c!的所有特殊三位数。
* 输入描述:没有输入。
* 程序输出:特殊三位数。
*/
#include <iostream>
using namespace std;
int main()
{
long fac(int n);
int a,b,c,n;
cout<<"满足特殊三位数条件的数有\n";
for(n=100; n<=999; n++)
{
a=n/100;
b=(n/10)%10;
c=n%10;
if(n==fac(a)+fac(b)+fac(c))
cout<<n<<endl;
}
return 0;
}
long fac(int n) //用于求n的阶乘
{
int s=1,i;
for(i=1; i<=n; i++)
s=s*i;
return s;
}
运行结果: