求出0~999之间的所有“水仙花数”并输出。“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;153=1+5+3?,则153是一个“水仙花数”。
方法一:
#include<stdio.h>
#include<math.h>
int main()
{
int i,j,k,n;
for(i=1;i<10;i++)
for(j=0;j<10;j++)
for(k=0;k<10;k++)
#include<math.h>
int main()
{
int i,j,k,n;
for(i=1;i<10;i++)
for(j=0;j<10;j++)
for(k=0;k<10;k++)
{
if(pow(i,3)+pow(j,3)+pow(k,3)==i*100+k*10+j)
printf("%d%d%d\n",i,j,k);
}
return 0;
}
if(pow(i,3)+pow(j,3)+pow(k,3)==i*100+k*10+j)
printf("%d%d%d\n",i,j,k);
}
return 0;
}
方法二:
#include<stdio.h>
#include<math.h>
int main()
{
int i = 100;
int nums = 0;
for (; i < 1000; i++){
if ( i < 10 ){
nums = 1;
}
else if ( i < 100 ){
nums = 2;
}
else{
nums = 3;
}
#include<math.h>
int main()
{
int i = 100;
int nums = 0;
for (; i < 1000; i++){
if ( i < 10 ){
nums = 1;
}
else if ( i < 100 ){
nums = 2;
}
else{
nums = 3;
}
int tmp = i;
int sum = 0;
while (tmp > 0){
sum += pow(tmp % 10, nums);
tmp /= 10;
}
if (sum == i){
printf("%d ", i);
}
}
printf("\n");
return 0;
}
int sum = 0;
while (tmp > 0){
sum += pow(tmp % 10, nums);
tmp /= 10;
}
if (sum == i){
printf("%d ", i);
}
}
printf("\n");
return 0;
}