C语言 简单粗暴的笨方法找水仙花数

作者:i跑跑 时间:2023-11-27 21:53:29 

什么是水仙花数:

指一个n位数,其各位数字的n次方之和确好等于该数本身

例如:? ?

1? ? ? ? ?1^1=1;

153? ? ? 3^3+5^3+1^3=153;

问题:求0~100000之间的水仙花数,并打印出来

看题目,找突破口:

  • 0~100000? 我可以想到用循环来判断0~10000间的数字

  • 由栗子可知:我们需要求数字是几位

  • 要用到次方,则我们需要引用math函数库里的pow函数

  • 求和,依旧要使用循环

那么开始写代码,走一步思考一步:


#include <stdio.h>
#include <math.h>

int main()
{
int i = 0;
for (i = 0; i <= 100000; i++)
{
int n = 1;                // n 为位数
int z = i;                //经过while后i改变,i未变前赋值给z,代替原值i进行后面的计算
while (z / 10 != 0)          //这里刚开始直接用i进行运算  死循环
{
n++;
z=z / 10;                //用i运算的话,当i=10时 i=i/10 直接等于1 ,死循环,所以用变量z代替i
}
if (i == Sum(i, n))        //判断和是否等于原值
printf("%d ",i);
}
return 0;
}

看代码一定要看后面的注释,这里要注意的点:

用了n代表位数,求n时while循环会改变i值,不利于后面的计算,所以用z代替

设置函数Sum来计算和,函数代码如下:


int Sum(int x, int y)               //x接收i,y接收n
{
int k = 0;
int num = 0;
int sum = 0;
for (k=0;k<y;k++)             //循环求和
{
num = pow(x % 10, y);      //取出每一位的数字,求次方
sum += num;                    //累加求和
x/=10;                  //去掉最低位的数字
}
return sum;               //返回和
}

完整代码如下:


#include <stdio.h>
#include <math.h>

int Sum(int x, int y)
{
int k = 0;
int num = 0;
int sum = 0;
for (k=0;k<y;k++)
{
num = pow(x % 10, y);
sum += num;
x/=10;
}
return sum;
}

int main()
{
int i = 0;
for (i = 0; i <= 100000; i++)
{
int n = 1;
int z = i;
while (z / 10 != 0)
{
n++;
z=z / 10;
}
if (i == Sum(i, n))
printf("%d ",i);
}
return 0;
}

运行结果:

C语言 简单粗暴的笨方法找水仙花数

这样找水仙花数就完成了? ? ? ? ? ? ? ? ? ? ??

来源:https://blog.csdn.net/weixin_53316121/article/details/121411624

标签:C语言,水仙花数
0
投稿

猜你喜欢

  • C#中数组、ArrayList、List、Dictionary的用法与区别浅析(存取数据)

    2021-05-27 03:55:49
  • 学习Java的9张思维导图

    2021-06-10 03:38:18
  • Java多线程中关于join方法的使用实例解析

    2023-08-22 21:47:29
  • 深入了解SparkSQL的运用及方法

    2023-06-08 13:43:27
  • Android使用多线程进行网络聊天室通信

    2022-05-11 18:56:36
  • SpringBoot集成MybatisPlus报错的解决方案

    2022-06-28 05:03:20
  • Android实现拍照添加时间水印

    2023-10-02 14:23:51
  • mybatis使用foreach查询不出结果也不报错的问题

    2023-11-24 22:36:17
  • Android StickListView实现悬停效果

    2022-06-06 15:54:35
  • Android ListView position详解及实例代码

    2023-10-29 03:33:15
  • SpringMVC框架post提交数据库出现乱码解决方案

    2022-03-01 09:50:41
  • SpringCloud之Config配置中心与Redis分布式锁详解

    2023-12-21 02:14:41
  • SpringBoot整合jersey的示例代码

    2021-08-28 05:23:12
  • java8 forEach结合Lambda表达式遍历 List操作

    2021-07-04 07:22:55
  • Android seekbar(自定义)控制音量同步更新

    2022-09-05 08:46:47
  • android实现简单音乐播放器

    2021-06-28 22:07:26
  • Java中关于泛型、包装类及ArrayList的详细教程

    2021-12-25 00:46:34
  • Java中遍历ConcurrentHashMap的四种方式详解

    2023-11-17 08:54:41
  • Java 数组获取最大和最小值的实例实现

    2021-06-18 15:53:06
  • Java客户端利用Jedis操作redis缓存示例代码

    2021-05-31 03:43:42
  • asp之家 软件编程 m.aspxhome.com