c语言 求出0-999之间的水仙花数并输出

求出0~999之间的所有“水仙花数”并输出。
“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;153=1+5+3?,则153是一个“水仙花数”。

/*
在数论中,水仙花数(Narcissistic number)也称为自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),是指一N位数,其各个数之N次方和等于该数。
例如153、370、371及407就是三位数的水仙花数,其各个数之立方和等于该数:
153 = 1^3 + 5^3 + 3^3。
370 = 3^3 + 7^3 + 0^3。
371 = 3^3 + 7^3 + 1^3。
407 = 4^3 + 0^3 + 7^3。
*/
//求出0-999之间的水仙花数并输出
//水仙花数指的就是一个数的各数位的立方等于这个数的值
//比如153就是一个水仙花数 153=13+53+3^3
#include<stdio.h>
#include<windows.h>
#include<math.h>
int ShuiXian(int num)
{
//首先将不满足条件的部分筛选出来
//return 0 即不满足条件的部分,return 是满足条件的部分
//首先<99的数和>999的是不满足本题的条件的
if (num < 99 || num>999)
{
//此处的||表示的是逻辑或,只要满足一个符号两边的一个条件,就进入条件语句
//return 0 表示不满足题意的部分我们筛选掉
return 0;
}
//这儿需要保存一下这个数,因为后面比较时会用到
int tep = num;
//将这个数的个位取出来
int ge = num % 10;
//然后去掉个位的部分,再进行计算
num /= 10;
int shi = num % 10;
num /= 10;
int bai = num % 10;
//这儿需要计算一个数的三次方来判断是否为水仙花数
//传统的方法太过于麻烦,所以这儿我们直接使用pow函数
//它的格式为pow(数字,次方数);
//记住因为它包含在math.h的头文件中,所以需要#include<math.h>
if (tep == pow(ge, 3) + pow(shi, 3) + pow(bai, 3))
{
//当满足条件时,return 1
return 1;
}
return 0;

}
int main()
{
//创建一个循环,遍历每一个数,判断是否为水仙花数
int i = 0;
for (i = 0; i <1000; i++)
{
//调用ShuiXian函数来判断一个数是否为水仙花数
//这儿调用ShuiXian函数可以判断i等于1,对应上面函数的出口
//但是也可以不写,因为在c语言中,非0即为1,条件也是满足的
if (ShuiXian(i) == 1)
{
printf("%d\n", i);
}
}
system(“pause”);
return 0;
}
程序的运行结果如下图所示
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值