(C语言)打印水仙花数

本文介绍如何使用C语言编程找出0到100000之间的所有水仙花数,水仙花数是指一个n位数,其各位数字的n次方之和等于该数本身。通过分解为多个函数,包括判断水仙花数、获取数字位数和循环查找,实现了问题的解决。代码附带注释以帮助理解每个函数的功能。
摘要由CSDN通过智能技术生成

求出0~100000之间的所有“水仙花数”并输出。“水仙花数”是指一个n位数,其各位数字的n次方之和确好等于该数本身,如:153=13+53+3^3,则153是一个“水仙花数”
这道题是一道较为经典的面试题,今天我想通过调用函数的方法,将该问题工程化,分为几个板块的函数,最终整体调用完成题面
基本思路:
第一步:编写一个函数判定一个数是不是水仙花数,从现在开始需要将问题细化;
第二步:判定该数字一共有多少(n)位,需要将每一位取出来,进行x^n+…
第三步:写一个函数叫他在1-100000之间循环,找出里边的所有符合条件的数字即可
(代码如下,可配合注释理解每一个函数的用意)

#include<stdio.h>
#include<math.h>
#include<windows.h>
int Count(int x)
{
 int count = 0;
 while (x)
  {  
   x /= 10; 
   count++; 
  }
 }                  //这一块函数就是最后一块,统计每个数字的位数,循环%10,用count++最终显示位数,很简单
int IsNarcissus(int x)
{
  int old_date = x; 
  int count = Count(x);//这里又需要引出另一个函数,就是统计每个数的位数   
  int sum = 0;
  while (x) 
   { 
    int GeWei = x % 10;//这里是将每个数的每一位数字取出来 
    pow(GeWei, count);  
    sum += (int)pow(GeWei, count); 
    x /= 10;
   } 
   if (sum == old_date) 
    {  
    return 1; 
    }
     else 
     { 
      return 0;
     }           //这一块函数就是判定标准
}
 int main()
 { 
      int i = 0; 
      for (i = 0; i < 100000; i++)
       {  
       if (IsNarcissus(i)) 
       {  
        printf("%d\n",i); 
       }
       }//首先这一块函数就是判定它是不是水仙花数,如果是,就将他打印出来,然后我们就得再写一个函数,来解释判定标准,我们将新函数写到上面
    system("pause");
     return 0;
 }

在这里插入图片描述
仅代表个人做法,欢迎各位爱好者批评指正

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值