codeforces #464C Substitutes in Number

题目大意:给定一个 105 位的数字,每次操作选择一个数字 x(0x9) ,将所有的 x 替换成数字串s,求最终的结果  mod 109+7
由于最终数字的长度是指数级别的,我们不能模拟
考虑倒着做
fi,j 表示执行 [i,n] 中的所有操作后数字 j(0j9) 会变成什么
当然这个数字可能非常大,因此我们只需要储存变换后的数值对 109+7 的模数以及变换后的位数对 109+6 的模数就行了
然后……随便搞一搞就好了

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define M 100100
#define MOD 1000000007
using namespace std;
int n;
pair<int,int> f[M][10];
int a[M];
char s[M],mempool[M<<1],*C=mempool,*st[M];
long long Quick_Power(long long x,int y)
{
    long long re=1;
    while(y)
    {
        if(y&1) (re*=x)%=MOD;
        (x*=x)%=MOD; y>>=1;
    }
    return re;
}
pair<int,int> Calculate(char s[],pair<int,int> table[10])
{
    pair<int,int> re(0,0);
    int i;
    for(i=0;s[i];i++);
    for(i--;~i;i--)
    {
        (re.first+=Quick_Power(10,re.second)*table[s[i]-'0'].first%MOD)%=MOD;
        (re.second+=table[s[i]-'0'].second)%=(MOD-1);
    }
    return re;
}
int main()
{
    static char buffer[M];
    int i,j;
    scanf("%s",s);
    cin>>n;
    for(i=1;i<=n;i++)
    {
        scanf("%s",buffer);
        a[i]=buffer[0]-'0';
        strcpy(C,buffer+3);
        st[i]=C;while(*C++);
    }
    for(i=0;i<10;i++)
        f[n+1][i]=make_pair(i,1);
    for(i=n;i;i--)
    {
        for(j=0;j<10;j++)
            if(a[i]!=j)
                f[i][j]=f[i+1][j];
            else
                f[i][j]=Calculate(st[i],f[i+1]);
    }
    cout<<Calculate(s,f[1]).first<<endl;
    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值