一、程序及代码。
/*
* 文件名称: 特殊三位数
* 作 者: 杨佳卫
* 完成日期: 2016 年 6 月 5 日
* 版 本 号:v1.0
* 对任务及求解方法的描述部分:
* 输入描述: 略
* 问题描述: 输出满足条件n=a!+b!+c!的所有三位数n,其中,a、b、c分别是n的百、十、个位数。
* 程序输出: int f(int m)
* 问题分析: 采用自定义函数的形式编程
* 算法设计: 略
*/
#include<iostream>
using namespace std;
int f(int m)
{
int i,j=1;
for(i=1;i<=m;i++)
j=i*j;
return j;
}
int main()
{
int a,b,c,n;
for(n=100;n<=999;n++)
{
a=n/100;
b=n/10-a*10;
c=n%10;
if(n==f(a)+f(b)+f(c))
cout<<"这个特殊数为:"<<n<<endl;
}
return 0;
}
二、运行结果。
三、心得及体会。
这个程序的关键在于自定义函数的引用,由于是第一次尝试这种类型的题目,遇到了许多困难,好在在一段时间的摸索下解决了。
四、知识点总结。
int f(int m)
{
int i,j=1;
for(i=1;i<=m;i++)
j=i*j;
return j;
}
本文介绍了一种使用C++编程语言解决数学问题的方法——找出所有符合条件的特殊三位数n,使得n等于其各位数字的阶乘之和。通过自定义阶乘函数并遍历所有可能的三位数来实现。
5780

被折叠的 条评论
为什么被折叠?



