C语言完成输出1~100000之间的水花仙数。

本文深入探讨了水仙花数的概念及其算法实现,通过具体的C语言代码解析了如何判断一个数是否为水仙花数,包括确定位数、分离各位数字及计算各数字的次方和。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

水花仙数的介绍
“水仙花数”是指一个n位数,其各位数字的n次方之和确好等于该数本身,如:153=13+53+3^3,则153是一个“水仙花数”。

该题难点:

  • 确定其位数
  • 分离其个位,十位,百位,千位,万位的数字
  • 将各位数字按位数进行次方相乘

解决方案:

1.我将确定位数和分离各位的具体数字结合一起解决,意思是我只要进行一次位数的分离就计数器加一(位数)。

分离各位数具体数的函数:

int Fenli(int p)

{

	int m = 0;

	m = p % 10;

	return m;

}

确定位数方法:

while (bianl> 0)//nianl为临时变量为防止改变我的n的数值。
		{

			jw++;

			sum[jw] = Fenli(bianl);

			bianl = bianl / 10;

		}

如何将各位数字的具体数按位数次方相乘:

	for (jw; jw >= 1; jw--)//jw为进行进位次数

		{
			for (ws = wd, lshi = 1; ws >= 1; ws--)//ws为位数,wd为防止下次进入循环时ws改变。

			{

				lshi = lshi* sum[jw];

			}

			jieguo += lshi;//相加的结果,用于最后和初始值n判断是否相等。

		}

源码如下:

#define _CRT_SECURE_NO_WARINGS 1

#include<stdio.h>

int Fenli(int p);

int main()

{

	int n = 1;

	int sum[10] = { 0 };

	int jw = 0;

	int ws = 1;

	int lshi = 1;

	int jieguo = 0;

	int wd = 0;

	int bianl = 0;

	for (n = 0; n <= 100000; n++)

	{

		jieguo = 0;

		bianl = n;

		jw = 0;

		while (bianl> 0)

		{

			jw++;

			sum[jw] = Fenli(bianl);

			bianl = bianl / 10;

		}

		wd = ws = jw;

		for (jw; jw >= 1; jw--)

		{

			for (ws = wd, lshi = 1; ws >= 1; ws--)

			{

				lshi = lshi* sum[jw];

			}

			jieguo += lshi;

		}

		if (jieguo == n)

			printf("%d ", n);

	}



	return 0;

}

int Fenli(int p)

{

	int m = 0;

	m = p % 10;

	return m;

}

运行结果如下;
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值