所谓"水仙花数"是指一个三位数,其各位数字之和的立方等于该数本身,例如:153是水仙花数,因为153=13+53+33
代码实现:
一一列举for循环嵌套
1 #include<iostream> 2 using namespace std; 3 void main() 4 { 5 int a,b,c,m,n; 6 for(a=1;a<=9;a++) 7 for(b=1;b<=9;b++) 8 for(c=1;c<=9;c++) 9 {10 m=a*a*a+b*b*b+c*c*c;11 n=100*a+10*b+c;12 if(m==n)13 cout<<a<<' '<<b<<' '<<c<<endl;14 }15 }16 17
另一种解法:
1 #include<iostream> 2 using namespace std; 3 void main() 4 { 5 int a,b,c,m; 6 for(m=100;m<=999;m++) 7 { 8 a=m/100; 9 b=(m%100)/10; 10 c=m%10; 11 if(a*a*a+b*b*b+c*c*c==m) 12 cout<<a<<' '<<b<<' '<<c<<endl; 13 } 14 }
运行结果:
来源:https://www.cnblogs.com/iamvirus/archive/2012/04/07/2437161.html