51Nod 1015 水仙花數

思路:簡單題,打個表就行(固然也能夠直接存數,可是小菜鳥的太懶了),代碼以下

#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;}
    }
}

 

若是哪裏有問題的但願你們指出來呀,畢竟我也只是個小菜鳥呢。c++

相關文章
相關標籤/搜索