C/C++/Python实现水仙花数(daffodil)

C/C++/Python实现水仙花数(daffodil)C/C++实现水仙花数(daffodil)题目:输出100~999中所有的水仙花数

C/C++/Python实现水仙花数(daffodil)"

C/C++/Python实现水仙花数(daffodil)

题目输出100~999中所有的水仙花数。若3位数ABC满足 A B C = A 3 + B 3 + C 3 ABC=A^3+B^3+C^3 ABC=A3+B3+C3,则称其为水仙花数。例如 153 = 1 3 + 5 3 + 3 3 153=1^3+5^3+3^3 153=13+53+33,所以153是水仙花数。

C代码
#include<stdio.h>
#include<math.h>
int main()
{ 
     
	int num ,a,b,c;
	for(num  = 100; num  <= 1000; x++)
	{ 
   
		a = num / 100;   			                        //求解百位a
		b = num / 10 % 10;		                            //求解十位b
		c = num % 10;				                        //求解个位c
		if(num == pow(a,3) + pow(b,3) + pow(c,3))			//水仙花数的公式
			printf("%d\n",num);	//输出
	}
	return 0;
}
Python代码
for num in range(100,1000):
    a = num // 100                              #求解百位a
    b = num // 10%10                            #求解十位b 
    c = num % 10                                #求解个位c
    if num == pow(a,3) + pow(b,3) + pow(c,3):   #水仙花数的公式
        print(num)
C++代码
#include <iostream>
#include <cmath>
using namespace std;
 
int main(int argc, const char * argv[]) { 
   
    int num, a, b, c;                                  
    
    for(num = 100; num < 1000; n++) { 
   
        a= n / 10;                                     // 求解百位a
        b = (n / 10) % 10;                             // 求解十位b 
        c= n % 100;                                    // 求解个位c 
        if(num  == pow(x, 3) + pow(y, 3) + pow(z, 3))  // 水仙花数的公式
            cout << n << " ";
    }
    cout << endl;
    return 0;
}

其实解法是一样的,只是各个语言的语法略有差别。
都是先求出个位、十位和百位,然后求立方再相加,刚入门,可能唯一难想的就是怎么求各个位数。

今天的文章C/C++/Python实现水仙花数(daffodil)分享到此就结束了,感谢您的阅读。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:http://bianchenghao.cn/89252.html

(0)
编程小号编程小号

相关推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注