CF1513C.Add One
2022/1/29 23:05:07
本文主要是介绍CF1513C.Add One,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目:
分析:记忆化搜索,9的贡献为两部分。
1 #include <bits/stdc++.h> 2 using namespace std; 3 int n, m; 4 const int mod = 1e9+7; 5 vector<vector<int>>f; 6 7 int dp(int d, int m){ 8 if(!m) return 1; 9 if(~f[d][m]) return f[d][m]; 10 int res = 0; 11 if(d==9){ 12 res=(dp(1, m-1)+dp(0, m-1))%mod; 13 }else{ 14 res=dp(d+1, m-1); 15 } 16 return f[d][m] = res; 17 } 18 19 int main(void){ 20 ios::sync_with_stdio(false); 21 cin.tie(0); 22 int T; 23 cin>>T; 24 f.resize(10, vector<int>(2e5+1, -1)); 25 for(int i=0; i<10; i++)dp(i, 2e5); 26 while(T--){ 27 cin>>n>>m; 28 int res = 0; 29 while(n){ 30 (res+=f[n%10][m])%=mod; 31 n/=10; 32 } 33 cout<<res<<'\n'; 34 } 35 return 0; 36 }
这篇关于CF1513C.Add One的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-09-28pyqt 怎么打包整个项目-icode9专业技术文章分享
- 2024-09-28laravel Commands 创建带有参数的 Artisan 命令的步骤和示例-icode9专业技术文章分享
- 2024-09-28antd怎么实现渲染tiff图片-icode9专业技术文章分享
- 2024-09-28英文半角中划线和中文全角的中划线有什么区别-icode9专业技术文章分享
- 2024-09-28nvm npm 和node 他们之间有什么关系-icode9专业技术文章分享
- 2024-09-28Node Version Manager (nvm)使用教程-icode9专业技术文章分享
- 2024-09-28nvm命令太慢,是什么原因-icode9专业技术文章分享
- 2024-09-28Kotlin 如何增加、删除和修改 MutableStateFlow 中的值。-icode9专业技术文章分享
- 2024-09-28Kotlin的stateFlow.update 写法介绍-icode9专业技术文章分享
- 2024-09-28kotlin 怎么获取当前时间格式-icode9专业技术文章分享