codeforces #464C Substitutes in Number
来源:互联网 发布:数据备份与维护 编辑:程序博客网 时间:2024/05/18 06:23
题目大意:给定一个
由于最终数字的长度是指数级别的,我们不能模拟
考虑倒着做
当然这个数字可能非常大,因此我们只需要储存变换后的数值对
然后……随便搞一搞就好了
#include <cstdio>#include <cstring>#include <iostream>#include <algorithm>#define M 100100#define MOD 1000000007using 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 0
- codeforces 464C Substitutes in Number
- Codeforces 464C Substitutes in Number
- 【DP】 codeforces 464C Substitutes in Number
- Codeforces 464 C. Substitutes in Number
- codeforces 464C Substitutes in Number dp
- codeforces #464C Substitutes in Number
- Codeforces 464C Substitutes in Number 同余定理+模拟
- Codeforces 464C Substitutes in Number(高效+快速幂)
- Codeforces 464 C. Substitutes in Number 动态规划法题解
- Codeforces Round #265 (Div. 2)E. Substitutes in Number(数学)
- Codeforces Round #265 (Div. 2) E. Substitutes in Number
- random number in C
- Missing number in C
- Codeforces 118C Fancy Number
- 【CODEFORCES】 C. Number of Ways
- codeforces 466C C. Number of Ways
- Codeforces Round #209 C - Prime Number
- Codeforces 209 div2 C. Prime Number
- Linux内核中内存相关的操作函数-1
- 排序算法系列之插入排序
- 播放器学习
- C++ 模板详解
- 排序算法系列之选择排序
- codeforces #464C Substitutes in Number
- OCP-1Z0-051-2015-17题
- GRE词汇记忆备考常见误区
- CSS字体
- Linux中grep
- Android 调用优酷SDK上传视频
- 排序算法系列之快排
- MDK配置jlink仿真器步骤
- Java GUI程序设计的初步上