Bootstrap

C语言初阶习题(6指针)【21】打印水仙花数

1. 题目描述

求出0~100000之间的所有“水仙花数”并输出。

在这里插入图片描述

2. 思路

一开始脑袋都成浆糊了。就是我需要判断这个数字是几位数,我需要求出这个数的每一位,当时混在一起考虑根本然不清。然后就想到了分开,写一个函数单求这个数字是几位数的,单独写一个函数求这个数字的n次方。单独写一个函数来判断它是否是水仙花数。

  1. 求一个数字有几位数
    思路:小于9就是1位数,大于9开始就要计算,所以我们的条件是是否大于9,因为我们需要处理的情况是大于9的,小于9的我们默认就是1
int sizeNum(int n)
{
	int size = 1;
	while (n > 9)
	{
		n = n / 10;
		size++;
	}
	return size;
}
  1. 求一个数字的次方
    思路:这个也比较简单,需要传入两个参数,我们要求次方的数字,和要求的次方数,for循环,要求几次,乘几次
int powNum(int n,int m)
{
	int i = 0;
	if (n == 0)
	{
		return 0;
	}
	int a = 1;

	for(int i = 0;i<m;i++)
	{
		a *= n;

	}
	return a;
}
  1. 求水仙花数,这个函数就用到了上面俩函数
    思路:先调用求出我们是几位数,函数专心考虑取出我们的每一位,然后调用求次方相加
int flawerNum(int n)
{
	int sum = 0;
	int num = n;   //这里我原本是没有另外创建临时变量来接收我们传入的参数,
	//然后在if判断的时候就有问题了,我们最后还需要使用这个n的值,所以应该再创建一个局部变量
	int size = sizeNum(num);


	int i = 0;
	for (i = 0; i < size; i++)
	{
		sum += powNum(num % 10, size);
		num = num / 10;
	}
	if (n == sum)
	{
		return 1;
	}
	else
	{
		return 0;
	}

}

3. 代码实现

求0-100000的水仙花数,我们for循环,调用即可。

//求出0~100000之间的所有“水仙花数”并输出。
//“水仙花数”是指一个n位数,其各位数字的n次方之和确好等于该数本身,如:153=1 ^ 3+5 ^ 3+3 ^ 3,则153是一个“水仙花数”。
#include<stdio.h>


int sizeNum(int n)
{
	int size = 1;
	while (n > 9)
	{
		n = n / 10;
		size++;
	}
	return size;
}

int powNum(int n,int m)
{
	int i = 0;
	if (n == 0)
	{
		return 0;
	}
	int a = 1;

	for(int i = 0;i<m;i++)
	{
		a *= n;

	}
	return a;
}


int flawerNum(int n)
{
	int sum = 0;
	int num = n;   //这里我原本是没有另外创建临时变量来接收我们传入的参数,
	//然后在if判断的时候就有问题了,我们最后还需要使用这个n的值,所以应该再创建一个局部变量
	int size = sizeNum(num);


	int i = 0;
	for (i = 0; i < size; i++)
	{
		sum += powNum(num % 10, size);
		num = num / 10;
	}
	if (n == sum)
	{
		return 1;
	}
	else
	{
		return 0;
	}

}

int main ()
{

	//printf("%d ", powNum(5, 3));

	
	//printf("%d ", flawerNum(153));
	int num = 0;
	
	for (num = 0;num < 100000; num++)
	{
		if (flawerNum(num)==1)
		{
			printf("%d ",num);
		}
		
	}
	return 0;
}

在这里插入图片描述

;