zoukankan      html  css  js  c++  java
  • hdu 5015

    思路:

    第一列元素为:

    0

    a1

    a2

    a3

    a4

    转化为:

    23

    a1

    a2

    a3

    a4

    3

    则第二列为:

    23*10+3

    23*10+3+a1

    23*10+3+a1+a2

    23*10+3+a1+a2+a3

    23*10+3+a1+a2+a3+a4

    3

    根据前后两列的递推关系,有等式可得矩阵A的元素为:

    嗯,然后跑矩阵快速幂就好了,这里的递推公式是一列一列的来,这个得理清楚。

    ac代码:

    #include <cstdio>
    #include <cstring>
    #include <iostream>
    #include <queue>
    #include <stack>
    #define mt(a) memset(a,0,sizeof(a))
    using namespace std;
    typedef long long ll;
    const ll mod=10000007;
    struct Martix
    {
        ll mp[20][20];
        ll r,c;
    };
    Martix mul(Martix a,Martix b)
    {
        ll r=a.r;
        ll c=b.c;
        Martix temp;
        temp.r=r;
        temp.c=c;
        for(int i=0;i<r;i++)
        {
            for(int j=0;j<c;j++)
            {
                temp.mp[i][j]=0;
                for(int k=0;k<r;k++)
                {
                    temp.mp[i][j]=(a.mp[i][k]*b.mp[k][j]%mod+temp.mp[i][j])%mod;
                }
            }
        }
        return temp;
    }
    ll temp[20];
    ll n,m;
    int pow(Martix a,int k)
    {
        Martix ans; // 
        ans.r=n+2;
        ans.c=1;
        memset(ans.mp,0,sizeof(ans.mp));
        ans.mp[0][0]=23;
        for(int i=1;i<=n;i++) ans.mp[i][0]=temp[i];
        ans.mp[n+1][0]=3;
      //  for(int i=0;i<n+2;i++) cout<<ans.mp[i][0]<<' ';
       // cout<<endl;
        while(k)
        {
            if(k&1) ans=mul(a,ans);
            k/=2;
            a=mul(a,a);
        }
      // for(int i=0;i<n+2;i++) cout<<ans.mp[i][0]<<' ';
       // cout<<endl;
        return ans.mp[n][0]%mod;
    }
    int main()
    {
    
        while(~scanf("%lld %lld",&n,&m))
        {
            Martix a;// 系数矩阵
            memset(temp,0,sizeof(temp));
            for(int i=1;i<=n;i++) scanf("%lld",&temp[i]);
            if(n==0)
            {
                cout<<temp[m]%mod<<endl;
                continue;
            }
            a.r=n+2;
            a.c=n+2;
            memset(a.mp,0,sizeof(a.mp));
            a.mp[0][0]=10;
            a.mp[0][n+1]=1;
            for(int i=1;i<=n;i++)
            {
                a.mp[i][0]=10;
                a.mp[i][n+1]=1;
                for(int j=1;j<=i;j++) a.mp[i][j]=1;
            }
            a.mp[n+1][n+1]=1;
            ll key=pow(a,m);
            cout<<key<<endl;
        }
        return 0;
    }
  • 相关阅读:
    .NET/C# 使用 SetWindowsHookEx 监听鼠标或键盘消息以及此方法的坑
    使用UI Automation实现自动化测试--1-4
    使用npm命令下载sass时出现Error: not found: python2
    CentOS上安装Python3
    解决electron打包时,下载超时导致失败
    FJ省队集训2021
    微信小程序自定义封装组件-showModal
    react性能优化
    认识react虚拟Dom
    前端FileReader读取文件信息
  • 原文地址:https://www.cnblogs.com/z1141000271/p/7530573.html
Copyright © 2011-2022 走看看