P1045 [NOIP2003 普及组] 麦森数

老师给的题解

#include<iostream>
#include<cstring>
#include<cmath>
using namespace std;
int s[1000],ts[1000],lents,lens=1,a[1000],lena=1,ta[1000],lenta;
int p;
void ksm(int p)
{
    s[1]=1,a[1]=2;
    while(p!=0)
    {
        if(p%2==1)
        {
            memset(ts,0,sizeof(ts));
            for(int i=1;i<=501;i++)
            {
                for(int j=1;j<=501;j++)
                {
                    ts[i+j-1]+=s[i]*a[j];
                }
            }
            for(int i=1;i<=501;i++)
            {
                if(ts[i]>=10)
                {
                    ts[i+1]+=ts[i]/10;
                    ts[i]%=10;
                }
            }
            for(int i=1;i<=501;i++)
            {
                s[i]=ts[i];
            }
            //s1=s1*a1;
        }
        p/=2;
        memset(ta,0,sizeof(ta));
        for(int i=1;i<=501;i++)
        {
            for(int j=1;j<=501;j++)
            {
                ta[i+j-1]+=a[i]*a[j];
            }
        }
        for(int i=1;i<=501;i++)
        {
            if(ta[i]>=10)
            {
                ta[i+1]+=ta[i]/10;
                ta[i]%=10;
            }
        }
        for(int i=1;i<=501;i++)
        {
            a[i]=ta[i];
        }
        //a1=a1*a1;
    }
}
int main()
{
    cin>>p;
    cout<<(int)(p*log10(2)+1)<<endl;
    ksm(p);
    int k=0;s[1]=s[1]-1;
    for(int i=500;i>=1;i--)
    {
        k++;
        cout<<s[i];
        if(k%50==0) cout<<endl;
    }
    return 0;
}

老师临时写的样例

#include<iostream>
#include<cstring>
#include<cmath>
using namespace std;
int p;
int a[505],s[505],c[505],d[505],len=1;
void work1()//处理进位 
{
    for(int i=1;i<=500;i++)
    {
        d[i+1]+=d[i]/10;d[i]%=10;
    }
}
void work2()//处理进位 
{
    for(int i=1;i<=500;i++)
    {
        c[i+1]+=c[i]/10;c[i]%=10;
    }
}
void ksm(int b)//快速幂 
{
    s[1]=1,a[1]=2;
    while(b>0)
    {
        if(b%2==1)
        {
            memset(d,0,sizeof(d));//清零 
            for(int i=1;i<=500;i++)
            {
                for(int j=1;j<=500;j++)
                {
                    d[i+j-1]+=s[i]*a[j];//
                }
            }
            work1();
            for(int i=1;i<=500;i++) s[i]=d[i];//
        }
        b=b/2;
        memset(c,0,sizeof(c));
        for(int i=1;i<=500;i++)
            {
                for(int j=1;j<=500;j++)
                {
                    c[i+j-1]+=a[i]*a[j];
                }
            }
            work2();
            for(int i=1;i<=500;i++) a[i]=c[i];
    }
}
int main()
{
    cin>>p;
    int k=(int)(p*(log10(2)))+1;
    cout<<k<<endl;
    ksm(p);
    if(s[1]>0) s[1]=s[1]-1;
    else
    {
        for(int i=1;i<=500;i++)
        {
            s[i+1]--;s[i]=s[i]-1+10;
        }
    }
    for(int i=500;i>=1;i--) cout<<s[i];
    return 0;
}

版权声明 :

若文中无特殊说明,则本文为原创文章,版权归 幻沙 所有。
所有原创文章采用 知识共享署名-非商业性使用 4.0 国际许可协议 进行许可。
您可以自由的转载和修改,但请务必注明文章来源并且不可用于商业目的。

本文链接:

https://crash-logs.cn/wrong/crash-2021-05-14_163-client.txt
1 + 9 =
快来做第一个评论的人吧~