数位DP
2021/7/20 6:05:49
本文主要是介绍数位DP,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
#include<bits/stdc++.h> #define N 22 #define M 11 #define db double #define ll long long #define ldb long double #define ull unsigned long long using namespace std; const int h=3,ki=149,mo=998244353; int mod(int x){return (x%mo+mo)%mo;} int inc(int x,int k){x+=k;return x<mo?x:x-mo;} int dec(int x,int k){x-=k;return x>=0?x:x+mo;} int ksm(int x,int k) { int ans=1; while(k){if(k&1)ans=1ll*ans*x%mo;k>>=1;x=1ll*x*x%mo;} return mod(ans); } int inv(int x){return ksm(x,mo-2);} int read() { char ch=0;int x=0,flag=1; while(!isdigit(ch)){ch=getchar();if(ch=='-')flag=-1;} while(isdigit(ch)){x=(x<<3)+(x<<1)+ch-'0',ch=getchar();} return x*flag; } void write(int x) { if(!x)return (void)putchar(48); if(x<0)putchar(45),x=-x; int len=0,p[20]; while(x)p[++len]=x%10,x/=10; for(int i=len;i>=1;i--)putchar(p[i]+48); } int a[N],dp[N][M][2]; int solve(int s) { if(s==0)return 0; int n=0;while(s)a[++n]=s%10,s/=10;reverse(a+1,a+n+1); memset(dp,0,sizeof(dp)); for(int i=1;i<=a[1];i++)dp[1][i][i==a[1]]=1; for(int x=2;x<=n;x++)for(int i=1;i<=9;i++)dp[x][i][0]=1; for(int x=1;x<n;x++) for(int lst=0;lst<=9;lst++) if(dp[x][lst][0]||dp[x][lst][1]) for(int i=0;i<=9;i++)if(abs(i-lst)>=2) { int f0=dp[x][lst][0]; int f1=dp[x][lst][1]; int &g0=dp[x+1][i][0]; int &g1=dp[x+1][i][1]; if(i<a[x+1])g0+=f0+f1; if(i>=a[x+1])g0+=f0; if(i==a[x+1])g1+=f1; } int ans=0; for(int lst=0;lst<=9;lst++)ans+=dp[n][lst][0]+dp[n][lst][1]; return ans; } int main() { int l=read(),r=read(); write(solve(r)-solve(l-1)); return 0; }
这篇关于数位DP的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-09必试!帮 J 人团队解决物流错发漏发的软件神器!
- 2025-01-09不容小觑!助力 J 人物流客服安抚情绪的软件!
- 2025-01-09为什么医疗团队协作离不开智能文档工具?
- 2025-01-09惊叹:J 人团队用啥软件让物流服务快又准?
- 2025-01-09如何利用数据分析工具优化项目资源分配?4种工具推荐
- 2025-01-09多学科协作难?这款文档工具可以帮你省心省力
- 2025-01-09团队中的技术项目经理TPM:工作内容与资源优化策略
- 2025-01-09JIT生产管理法:优化流程,提升竞争力的秘诀
- 2025-01-092024全球互联网流量分析报告
- 2025-01-09如何提升学校行政管理中的进度追踪效率?4个实用策略和3款工具推荐