zoukankan      html  css  js  c++  java
  • project euler-34

    145是个奇怪的数字。由于1!+ 4! + 5! = 1 + 24 + 120 = 145。

    请求出能表示成其每位数的阶乘的和的全部数的和。

    请注意:由于1! = 1和2! = 2不是和,故它们并不包含在内。

    ---------------------------------------------------

    原来0的阶乘是1。。。。我弱智了。。。

    粗略的运算一下数据范围。发现不会超过1000W。

    于是,暴力吧。

    (事实上结果仅仅有两个数符合规律。

    。。)

    #include<stdio.h>
    #include<algorithm>
    #include<iostream>
    #include<stdlib.h>
    #include<vector>
    #include<queue>
    #include<string.h>
    #include<math.h>
    using namespace std;
    int fat[10];
    void init()
    {
        fat[0]=1;
        fat[1]=1;
        for(int i=2;i<=9;i++)
        {
            fat[i]=fat[i-1]*i;
        }
    }
    int cal(int x)
    {
        int ans=0;
        while(x)
        {
            ans=ans+fat[x%10];
            x=x/10;
        }
        return ans;
    }
    int main()
    {
        init();
        int sum=0;
        for(int i=10;i<=100000000;i++)
        {
            if(i==cal(i))
            {
                sum+=i;
            }
        }
        cout<<sum<<endl;
        return 0;
    }
    
    
    
    


查看全文
  • 相关阅读:
    金融数据获取的api接口
    股票实时数据接口
    【C#】通过webbrowser控件自动注册QQ号讲解
    【C#】通过webbrowser控件获取验证码
    光圈,快门, 曝光,焦距, ISO,景深。
    装修记录
    cocos2dx在win10系统上的VS2017运行时报错:丢失MSVCR110.dll
    论打击的本质(2)-视觉理论及应用篇
    论打击感的本质(1)——力的理论及应用
    android屏幕适配详解
  • 原文地址:https://www.cnblogs.com/ldxsuanfa/p/10905266.html
  • Copyright © 2011-2022 走看看