C语言 ——— 打印水仙花数

目录

何为水仙花数

题目要求

代码实现


何为水仙花数

"水仙花数"是指一个n位数,其各位数字的n次方之和等于该数本身

如:153 = 1^3 + 5^3 + 3^3,则153就是一个"水仙花数"


题目要求

求出0~100000的所有"水仙花数"并输出


代码实现

复制代码
#include<stdio.h>
#include<math.h>
int main()
{
	// 遍历0~100000的整数

	for (int i = 0; i <= 100000; i++)
	{
		// 计算i的位数
		int n = 1;
		int tmpi = i;
		while (tmpi = tmpi / 10)
			n++;

		// 计算i的每一位次方n后的和
		int sum = 0;
		tmpi = i;
		while (tmpi != 0)
		{
			sum = sum + pow(tmpi % 10, n);
			tmpi = tmpi / 10;
		}

		// 判断并输出打印
		if (sum == i)
			printf("%d\n", sum);
	}
	return 0;
}

代码解析:

1.先计算出当前数的位数有几位

2.再计算出当前数的每一位次方位数后的和

3.最后判断和是否等同于当前数

代码验证:

相关推荐
本喵是FW1 小时前
C语言手记1
java·c语言·算法
炘爚4 小时前
C语言(const的指针定义的区别)
c语言
Z9fish5 小时前
sse哈工大C语言编程练习47
c语言·数据结构·算法
本喵是FW5 小时前
C语言手记2
c语言·开发语言
计算机安禾6 小时前
【C语言程序设计】第34篇:文件的概念与文件指针
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
wangjialelele6 小时前
C++11、C++14、C++17、C++20新特性解析(一)
linux·c语言·开发语言·c++·c++20·visual studio
Book思议-7 小时前
【数据结构实战】链表找环入口的经典问题:快慢指针法
c语言·数据结构·算法·链表
Book思议-8 小时前
【数据结构实战】判断链表是否有环:快慢指针法(Floyd 判圈算法)
c语言·数据结构·算法·链表
qq_150841998 小时前
用CVI写一个贪吃蛇小游戏
c语言
C羊驼9 小时前
C 语言:哥德巴赫猜想
c语言·开发语言·人工智能·经验分享·笔记·算法·课程设计