51Nod 1015 水仙花数

2018-12-28 08:03:12来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

思路:简单题,打个表就行(当然也可以直接存数,但是小菜鸟的太懒了),代码如下

#include<bits/stdc++.h>
using namespace std;
int arr[20];
int num = 0;
void cal()
{

    arr[num++]=153;
    for(int i = 154; i <= 999 ; i++)
    {
        int a,b,c;
        a=i/100;
        b=i%100/10;
        c=i%10;
        if(i==(a*a*a+b*b*b+c*c*c)) arr[num++] = i;
    }
    for(int i = 1001; i <= 2000 ; i++)
    {
        int a,b,c,d;
        a=i/1000;
        b=i%1000/100;
        c=i%100/10;
        d=i%10;
        if(i==(a*a*a*a+b*b*b*b+c*c*c*c+d*d*d*d)) {arr[num++] = i;break;}
    }
}
int main()
{
    cal();
    int m; cin>>m;
    for(int i = 0 ; i < num; i++)
    {
        if(arr[i]>=m) {cout<<arr[i]<<endl;break;}
    }
}

 

如果哪里有问题的希望大家指出来呀,毕竟我也只是个小菜鸟呢。

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:51Nod 1004 n^n的末位数字

下一篇:VS2017 + QT5 + C++开发环境搭建和计算器Demo测试