求出所有[m,n]范围内的水仙花数
水仙花数是指一个三位数,它的各位数字的立方和等于其本身。
编程遇到的问题
c++如果表示x的y次方,可以用pow(x,y),记得加头文件#include<math.h>
也可以直接相乘,如xxx=pow(x,3)
起初运行时发现if条件语句没有起到任何作用,程序输出了m-n之间的所有数字。原因是将x的y次方表示成了x^y 。
正确代码如下:
解法1
int main(){
int m[100]={0},n[100]={0};
int i=1,count=1;
while(cin>>m[i]>>n[i]){
i++;count++;
}
i--;count--;//最后一次i++后没有录入m[i] n[i]
// for(int j=1;j<=i;j++){//结果证明正确录入了m n 数组
// cout<<m[j]<<" "<<n[j]<<endl;
// }
for(i=1;i<=count;i++){//对于每一行输入的范围
int flag=0;
for(int k=m[i];k<=n[i];k++){//k在范围n遍历
if(k==pow((k%10),3)+pow((k/10%10),3)+pow((k/100),3)){
cout<<k<<" ";
flag=1;
}
}
if(flag==0) cout<<"no";
cout<<endl;
}
return 0;
}
解法2
int main(){
int m,n;
while(cin>>m>>n){
int flag=1;//标志是否输出no
for(int i=m;i<=n;i++){
if(i==pow((i%10),3)+pow((i/10%10),3)+pow((i/100),3)){
cout<<i<<" ";
flag=0;
}
}
if(flag) cout<<"no";
cout<<endl;
}
return 0;
}