/*
*程序的版权和版本声明部分:
*Copyright(c)2013,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:
*完成日期:2013年 11月
*版本号:v1.0
*对任务及求解方法的描述部分:
*输入描述:
*问题描述:输出满足n=a!+b!+c!的所有三位数
*程序输出:满足的数
*问题分析:
*算法设计:
*/
#include<iostream>
using namespace std;
bool manzu(int);
int fac(int);
int main()
{
int n;
for(n=100;n<=999;n++)
{
if(manzu(n))
cout<<n<<"\t";
}
cout<<endl;
return 0;
}
int fac(int n)
{
int y=1,i;
for(i=n;i>=1;--i)
{
y*=i;
}
return y;
}
bool manzu(int n)
{
bool flag=false;
int a,b,c;
a=n/100; //百位数
b=n/10%10; //十位数
c=n%10; //个位数
if(n==fac(a)+fac(b)+fac(c))
flag=true;
return flag;
}
心得:自自己编程以来第一次用 i--发现还挺好用。嘿嘿。。