• 题解:[P1009 阶乘之和]


    - [P1009 阶乘之和](https://www.luogu.com.cn/problem/P1009)

    QAQ,刚开始看完题直接立刻按照题目阶乘相加写出了程序,数据使用int类型处理,4个测试点只通过两个。

    感觉应该是int型数据不够大,存不下结果,然后换成了long long测试一遍还是不行,又换成了unsigned long long,还是不够大,

    下载了第三个测试点看了一下,发现是22的阶乘,结果是1177652997443428940313, ̄□ ̄||。。。。。。。。。。

    //这个不行
    #include<iostream>
    #include<cmath>
    #include<iomanip>
    #include <stdio.h>
    #include <math.h>
    using namespace std;
    unsigned long long jc(unsigned long long n);
    int main()
    {
        unsigned long long n,s=1,s2=0;
        cin>>n;
        for(unsigned long long i = 1; i<=n; i++)
            s2+=jc(i);
        cout<<s2;
        return 0;
    }
    
    unsigned long long jc(unsigned long long n)
    {
        unsigned long long s = 1;
        for(unsigned long long i = 1; i<=n; i++)
            s*=i;
        return s;
    }

    发现题目提示用高精度计算,花了大半天用数组写了一个超长数据加法乘法器终于全部ac,

    #include<iostream>
    #include<sstream>
    using namespace std;
    class Operator
    {
    public:
        string input;
        int data[100];
        int length;
        void init();
        Operator(string s);
        void setdata(string s);
        void printdata();
        int adder(Operator ope);
        int subtractor(Operator ope);
        int multiplier(Operator ope,int n);
        int divider(Operator ope);
    };
    
    Operator::Operator(string s)
    {
        if(s=="0")
        {
            init();
        }
        else
        {
            for(int i = 0; i<100; i++)
            {
                data[i]=0;
            }
            input = s;
            length = s.length();
            stringstream ss;
            for(int i = 0; i<length; i++)
            {
                ss<<s[i];
                ss>>data[length-i-1];
                ss.clear();
            }
        }
    }
    
    void Operator::init()
    {
        for(int i = 0; i<100; i++)
        {
            data[i]=0;
        }
        input = "";
        this->length = 0;
    }
    
    void Operator::printdata()
    {
        cout<<"data = ";
        for(int i = length-1; i>=0; i--)
        {
            cout<<data[i];
        }
        if(length==0)
            cout<<"0";
        cout<<"  string ="<<input;
        cout<<"  length = "<<length;
        cout<<endl;
    }
    
    void Operator::setdata(string s)
    {
        input = s;
        length = s.length();
        stringstream ss;
        for(int i = 0; i<length; i++)
        {
            ss<<input[i];
            ss>>data[length-i-1];
            ss.clear();
        }
    }
    
    int Operator::adder(Operator ope)
    {
        int add_bit = 0;
        this->length = max(this->length,ope.length);
        for(int i = 0; i<max(this->length,ope.length); i++)
        {
            int d = this->data[i]+ope.data[i];
            if(add_bit!=0)
                d+=1;
            if(d>9)
                add_bit = 1;
            else
                add_bit = 0;
            this->data[i] = d%10;
        }
        if(add_bit==1)
        {
            this->data[length]=1;
            this->length = length+1;
        }
        stringstream ss;
        input.resize(this->length);
        for(int i = 0; i<this->length; i++)
        {
            ss<<data[this->length-i-1];
            ss>>this->input[i];
            ss.clear();
        }
        return 1;
    }
    
    int Operator::multiplier(Operator ope,int n)
    {
        Operator ope_copy(ope.input);
        for(int i = 1; i<n; i++)
        {
            this->adder(ope_copy);
        }
    
        return 1;
    }
    
    int Operator::subtractor(Operator ope)
    {
        return 0;
    }
    
    int Operator::divider(Operator ope)
    {
        return 0;
    }
    
    int main()
    {
        int n;
        cin>>n;
    
        Operator sum_factorial("0");
        for(int i = 1; i<=n; i++)
        {
            Operator factorial("1");
            for(int j = 1; j<=i; j++)
            {
                factorial.multiplier(factorial,j);
    
            }
    
            sum_factorial.adder(factorial);
        }
    
        cout<<sum_factorial.input;
    
    
        return 0;
    }

    真不容易,想刷点大水题。。。。。。。。。。

  • 相关阅读:
    SNF软件开发机器人-子系统-功能-启用大按钮样式如何配置
    SNF软件开发机器人-子系统-功能-数据录入方式
    SNF软件开发机器人-子系统-功能-功能类型(普通表改为树型表)
    SNF软件开发机器人-子系统-导出-导入功能-多人合作时这个功能经常用到
    SQL SERVER数据库删除LOG文件和清空日志的方案
    打不开磁盘“I:xxx.vmdk”或它所依赖的某个快照磁盘
    chrome浏览器解决跨域问题
    AngularJS判断checkbox/复选框是否选中并实时显示
    非常全的VsCode快捷键
    Oracle&SQLServer中实现跨库查询
  • 原文地址:https://www.cnblogs.com/mydrizzle/p/12601873.html
Copyright © 2020-2023  润新知