找出水仙花数
2012-10-17 07:28
134 查看
#include <iostream>
#include <cmath>
using namespace std;
int main()
{
int g_iMax =0;
cout << "pls put the max number: ";
cin>> g_iMax;
try
{
if (g_iMax < 0)
throw g_iMax;
}
//依次检查从0到输入的数据
for (int l_iLoop=0; l_iLoop <= g_iMax; l_iLoop++)
{
int l_iTmp1 =l_iLoop;
int l_iTmp2 =l_iLoop;
int l_iTt1 =0;
int l_iDgt =0;
//计算当前数据的位数
do
{
++l_iDgt;
l_iTmp1 = l_iTmp1/10;
}while(l_iTmp1);
//计算每个数据的对应的位数次幂的和
for (int i=0; i != l_iDgt; ++i)
{
l_iTmp1+= int (pow(double(l_iTmp2%10),double(l_iDgt)));
l_iTmp2 = l_iTmp2/10;
}
//检查位数次幂的和是否和当前位数相等
if (l_iLoop==l_iTt1)
{
cout << l_iTt1<< endl;
}
catch (int n)
{
cerr << "error,input number " << n <<"less than zero !" <<endl;
}
return 0;
}
}
#include <cmath>
using namespace std;
int main()
{
int g_iMax =0;
cout << "pls put the max number: ";
cin>> g_iMax;
try
{
if (g_iMax < 0)
throw g_iMax;
}
//依次检查从0到输入的数据
for (int l_iLoop=0; l_iLoop <= g_iMax; l_iLoop++)
{
int l_iTmp1 =l_iLoop;
int l_iTmp2 =l_iLoop;
int l_iTt1 =0;
int l_iDgt =0;
//计算当前数据的位数
do
{
++l_iDgt;
l_iTmp1 = l_iTmp1/10;
}while(l_iTmp1);
//计算每个数据的对应的位数次幂的和
for (int i=0; i != l_iDgt; ++i)
{
l_iTmp1+= int (pow(double(l_iTmp2%10),double(l_iDgt)));
l_iTmp2 = l_iTmp2/10;
}
//检查位数次幂的和是否和当前位数相等
if (l_iLoop==l_iTt1)
{
cout << l_iTt1<< endl;
}
catch (int n)
{
cerr << "error,input number " << n <<"less than zero !" <<endl;
}
return 0;
}
}
相关文章推荐
- Python一句代码实现找出所有水仙花数
- 找出所有三位数中的水仙花数
- 编写一个程序找出100~999之间所有的水仙花数
- 找出100~1000内的所有水仙花数
- 找出三位整数中所有的水仙花数
- C语言 找出水仙花数
- [置顶] js找出指定范围内(m,n)的水仙花数
- 找出所有的水仙花数:例如:153=1*1*1+5*5*5+3*3*3
- Java练习题1:找出100——999数中的所有水仙花数
- 水仙花数的找出
- 一个大的含有50M个URL的记录,一个小的含有500个URL的记录,找出两个记录里相同的URL
- 水仙花数
- 36个球找出其中一或轻或重球的问题
- 找出字符串中第一个只出现一次的字符
- 汇编语言,找出最大值与最小值
- 判断两个链表是否相交并找出交点
- 找出数组中第k大小的数,输出数所在的位置
- java在文章中找出关键词
- 找出数组中两个只出现一次的数字
- 找出重复最多的字符