C语言--打印出所有的水仙花数

   采用for循环,用穷举法思想求解。打印出所有“水仙花数”,所谓“水仙花数”,指的是一个三位数,其各位数字的立方和等于该数本身。例如:153=13+53+33。

   此处我们将用穷举法求解。即三位数x从100-999循环试探,如果满足“水仙花数”条件,那么此时的x就是一个解。重点思考如何将三位数分解成百位、十位、个位。

运行代码如下所示:

#include<stdio.h>
void main()
{
	int a,b,c,n;
	printf("3位数以内的水仙数为:\n");
	
	for(n=100;n<=999;n++)  //这里是让n在三位数以内
	{
		a=n/100;   //分解出个位
		b=n/10%10; //分解出十位
		c=n%100%10;//分解出百位
		
		if(n==a*a*a + b*b*b + c*c*c)
		printf("%d\n",n);//判断该数的各位数字的立方和是否等于该数本身(即水仙花数)
	}
}

运行结果如下图所示:

 

  • 12
    点赞
  • 46
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Pegasus丶百战

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值