1. 程式人生 > >兩種方法列印水仙花數

兩種方法列印水仙花數

一個三位數,它的個位的立方加上十位的立方再加上百位的立方等於這個數本身的話,此數叫作水仙花數.如:某三位數abc,如果滿足a^3+b^3+c^3=abc,則abc是水仙花數。下面我提供兩種方法列印水仙花數。

1.下面這個程式碼是比較好理解的,直接從水仙花的定義,結構a^3+b^3+c^3=abc入手,分別定義個位、十位、百位構造水仙花數。

#include<stdio.h>
#include<stdlib.h>
#include<math.h>
int main()
	{
	int i, j, k; int a;//j,j,k分別表示水仙花數的百位,十位,個位;a表示水仙花數
		for (i = 0; i <= 9; i++)
		{
			for (j = 0; j <= 9; j++)
			{
				for (k = 0; k <= 9; k++)
				{
					a= k + j * 10 + i * 100;
					if (a==i*i*i+j*j*j+k*k*k&& a>=100)
						printf("%d\n", a);
				}
			}
		}
		system("pause");
		return 0;
	}

2.下面的這個程式碼是由三位數分別計算他的個位、十位、百位,在來判斷他是否為水仙花數,也是比較好理解的

#include <stdio.h>
#include <stdlib.h>
int Isshuixianhua(int num)//num為需要判斷是否為水仙花數的整數
{
	int x1 = num % 10;//除以10的餘數=>個位
	int x2 = (num / 10) % 10;//=>十位
	int x3 = (num/ 100)%10;//=>百位
	if (x1*x1*x1 + x2*x2*x2 + x3*x3*x3 == num)
		return num;
	else
		return 0;
}
int main()
{
	int X=100;
	for (X = 100; X < 1000; X++)
	{
		if (Isshuixianhua(X) != 0)
			printf("%d\n", Isshuixianhua(X));
		else
			continue;
	}
     system("pause");
     return 0;
}