C语言 求出100~999之间的所有“水仙花数”并输出

    “水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;153=1^3+5^3+3^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。

代码如下:

#include<stdio.h>
int main()
{
	int num,i,j,k;
	printf("0到999之间的所有水仙花数:");
	for(num=100;num<1000;num++)
	{
	    i=num/100;/*求出百位数*/
	    j=num/10-i*10;/*求出十位数*/
	    k=num-i*100-j*10;/*求出个位数*/
	    if(i*i*i+j*j*j+k*k*k==num)
	    {
	    	printf("%d ",num);
	    }
	}
	return 0;
}

上述方法求出一个数的每位数较麻烦,利用for循环对此进行改进。

代码如下:

#include<stdio.h>
#include<math.h>
int main()
{
	int i;
	double sum;
	printf("输出0到999之间的所有水仙花数:\n");
	for(i=100;i<1000;i++)
	{/*不可在循环体内修改循环变量,防止for循环失去控制*/
		int num=i;/*引入变量num*/
		for(sum=0;num!=0;num/=10)
		{  
			sum+=pow(num%10,3);
		}
		if(sum==i)/*sum应与i比较,不是引入的变量num*/
		{
			printf("%d ",i);
		}
	}
	return 0;
}

本文出自 “Scen” 博客,请务必保留此出处http://10741357.blog.51cto.com/10731357/1701845

  • 6
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 好的,以下是用C语言列出100999之间水仙花数的代码: ```c #include <stdio.h> #include <math.h> int main() { int i, n, sum; printf("100~999之间水仙花数为:\n"); for (i = 100; i <= 999; i++) { n = i; sum = 0; while (n > 0) { sum += pow(n % 10, 3); n /= 10; } if (sum == i) { printf("%d\n", i); } } return 0; } ``` 运行结果为: ``` 100~999之间水仙花数为: 153 370 371 407 ``` 这里使用了循环和判断的方法,先将每个拆分成个位、十位和百位,然后计算出每一位的立方和,最后与原进行比较,如果相等则为水仙花数输出即可。 ### 回答2: 水仙花数是指一个三位,其各个位上的字的立方和等于该本身。为了列出100~999之间水仙花数,我们可以使用C语言编写一个程序。以下是一个简单的示例程序: #include <stdio.h> int main() { int num, last_digit, middle_digit, first_digit; printf("100~999之间水仙花数有:\n"); for (num = 100; num <= 999; num++) { first_digit = num / 100; middle_digit = (num / 10) % 10; last_digit = num % 10; if (num == (first_digit * first_digit * first_digit) + (middle_digit * middle_digit * middle_digit) + (last_digit * last_digit * last_digit)) { printf("%d ", num); } } return 0; } 上述程序首先定义了四个变量:num(用于循环迭代值),last_digit(个位),middle_digit(十位)和first_digit(百位)。 程序使用for循环100开始迭代到999。在循环中,使用简单的学运算,将num分解为个位、十位和百位。 然后,我们通过比较num是否等于三个位的立方和,判断是否为水仙花数。如果条件满足,则打印该字。 最终,程序输出100~999之间水仙花数。在控制台上,你会看到以下输出: 153 370 371 407
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值