C语言计算任意位数的水仙花数

一、水仙花数定义:

水仙花数(Narcissistic number)是指一个 n(n≥3) 位数,它的每个数位上的数字的 n 次幂之和等于它本身。例如 3 位数的 153:1³ + 5³ + 3³ = 153

二、C语言计算任意位数的水仙花数代码

c 复制代码
#include<stdio.h>

long int TenPower(int power)		// 计算 10 的 power 次幂
{
	if(power == 0){
		return 1;
	}
	long int result = 1;

	for(int i = 0;i < power; i++){
		result *= 10;
	}
	return result;
}	

int NumPower(int base, int power)		// 计算 base 的 power 次幂
{
	if(power == 0){
		return 1;
	}

	int result = 1;
	for(int i = 1; i <= power; i++){
		result *= base;
	}
	return result;
}

int main(void)
{
	int dig;				// 保存位数
	long int result;		// 保存次方计算结果
	
	puts("请输入位数(三位以上):");			// 根据水仙花数的定义,需要 3 位数及以上
	scanf("%d",&dig);
	if(dig < 3){
		puts("错误!位数必须为2以上!");
		return 0;
	}

	printf("%d位数的水仙花数有:", dig);
	for(long int i = TenPower(dig-1); i <= (TenPower(dig)-1); i++){			/* 根据给出的位数,拟定计算范围。
																			   如 3 位数计算范围为 100 ~ 999 */
		long int tmp = i;
		result = 0;
		for(int j = 1; j <= dig; j++){					// 计算每一位数字的 dig 次方
			result += NumPower(tmp/TenPower(dig-j), dig);			// 计算每一位数的 dig 次幂之和。例如计算 999 每一位的 dig 次幂之和
			tmp = tmp%TenPower(dig-j);								/* tmp 意为临时,便于计算每一位上的数字。
																	   例如计算 999,则首先计算 999/100 得到百位上数字为 9,
																	   然后 999%100 得到 99,然后 99/10 得到十位上数字为 9,
																	   然后 99%10 得到 9,然后 9/1 得到个位上数字为 9. */
		}
		if(i == result){					// 若该数字每一位数的 dig 次幂之和等于该数字,则为水仙花数
			printf("%ld ", i);
		}
		if(i == (TenPower(dig)-1)){			// 计算结束,换行符号
			puts("");
		}
	}

	return 0;
}

三、运行结果

相关推荐
EricWang13581 小时前
[OS] 项目三-2-proc.c: exit(int status)
服务器·c语言·前端
我是谁??1 小时前
C/C++使用AddressSanitizer检测内存错误
c语言·c++
希言JY2 小时前
C字符串 | 字符串处理函数 | 使用 | 原理 | 实现
c语言·开发语言
午言若2 小时前
C语言比较两个字符串是否相同
c语言
TeYiToKu4 小时前
笔记整理—linux驱动开发部分(9)framebuffer驱动框架
linux·c语言·arm开发·驱动开发·笔记·嵌入式硬件·arm
互联网打工人no14 小时前
每日一题——第一百二十四题
c语言
爱吃生蚝的于勒4 小时前
深入学习指针(5)!!!!!!!!!!!!!!!
c语言·开发语言·数据结构·学习·计算机网络·算法
羊小猪~~4 小时前
数据结构C语言描述2(图文结合)--有头单链表,无头单链表(两种方法),链表反转、有序链表构建、排序等操作,考研可看
c语言·数据结构·c++·考研·算法·链表·visual studio
洋2404 小时前
C语言常用标准库函数
c语言·开发语言
徐嵌5 小时前
STM32项目---畜牧定位器
c语言·stm32·单片机·物联网·iot