A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© Wangyk 中级黑马   /  2016-5-6 23:22  /  1553 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

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


  3. int main()
  4. {
  5.         /*三位水仙花数
  6.            概念:若三位数ABC满足ABC=A^3+B^3+C^3,则称为三位水仙花数。例如153=1^3+5^3+3^3,所以 153是水仙花数

  7.            实现步骤:
  8.                         1. 输入两个数,表示区间[a,b],由于求解的是三位的水仙花数,所以a>=100,b<=999,且b>a
  9.                         2. 实现算法,设数num,分解百位,十位,个位,然后各三次方相加,看是否和等于数num
  10.                         3. 输出水仙花数

  11.            这里需要引入一个方法pow(int x,int y) 要包含math.h头文件
  12.            实例:
  13.                 double x=2.0,y=3.0;
  14.                 printf("%lf的%lf次方是:%lf\n",x,y,pow(x,y));
  15.                 打印出:2.000000的3.000000次方是:8.000000
  16.         */
  17.        
  18.         //1 声明百位 十位 个位
  19.         int bai,shi,ge;
  20.         int num;

  21.         //2 实现算法
  22.         for(num=100;num<=999;num++)
  23.         {
  24.                 //2.1 百位、十位、个位分解
  25.                 bai = num/100;
  26.                 shi = num/10%10;
  27.                 ge  = num%10;
  28.                 //2.2 判断算法
  29.                 if(num == pow(bai,3)+pow(shi,3)+pow(ge,3))
  30.                 {
  31.                         printf("%d\n",num);
  32.                 }
  33.         }

  34.         return 0;
  35. }
复制代码

1 个回复

倒序浏览
学习了,继续加油!!
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马