C++题目,求解,谢谢!

5-23水仙花数(20分)水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。例如:153=13+53+33。本题要求编写程序,计算所有N位水... 5-23 水仙花数 (20分)
水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。例如:153=13+53+33。 本题要求编写程序,计算所有N位水仙花数。
输入格式:
输入在一行中给出一个正整数N(3≤N≤7)。
输出格式:
按递增顺序输出所有N位水仙花数,每个数字占一行。
输入样例:
3

输出样例:
153
370
371
407

请用最基本的循环嵌套来做!
打上注释,谢谢大神!
展开
 我来答
253110376
2015-11-02 · 超过51用户采纳过TA的回答
知道小有建树答主
回答量:106
采纳率:0%
帮助的人:68.1万
展开全部
#include<cstdio>
#include<cstring>
#include<iostream>
#include<cmath>
using namespace std;
int main()
{
int n;
cin>>n;
int a=pow(10.0,n-1),b=pow(10.0,n);
//区间[a,b)为所有n位的数
for(int i=a;i!=b;++i){//枚举[a,b)中的所有数 
int t=i,sum=0;//sum为每个位上的数字的N次幂之和 
while(t){
sum+=pow(double(t%10),n);//提取每一位并计算其n次幂,累加至sum 
t/=10;
}
if(sum==i)
cout<<i<<endl;
}
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式