博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CQOI2016 Number - 数位dp
阅读量:4316 次
发布时间:2019-06-06

本文共 1716 字,大约阅读时间需要 5 分钟。

题目描述

分析:

dp[哪一位][前一个数的倒数第二位][前一个数的倒数最后一位][0/1表示是否满足了至少有三个相邻数字的要求][0/1/2 (0:没有8和4;1:有8;2:有4)][0/1表示最高位到当前位小于或者等于R]

具体转移都在代码里了。

#include
#include
#define MAXL 20typedef long long LL;int lmt[MAXL+10];LL dp[MAXL+10][20][20][5][5][5];int Getorg(LL num){ int ret=0; for(LL x=num;x;x/=10) ret++; memset(lmt,0,sizeof lmt); int k=0; for(LL x=num;x;x/=10,k++) lmt[ret-k]=x%10; return ret;}inline int f(int x){ if(x==8) return 1; else if(x==4) return 2; else return 0;}inline int h(int x,int y,int z){ if(x==y&&y==z) return 1; else return 0;}LL DP(LL R){ int n=Getorg(R); if(R==10000000000LL-1) return 0; memset(dp,0,sizeof dp); for(int i=1;i
< R for(int p=0;p<=9;p++) dp[i][k][p][h(j,k,p)][f(p)][0]+=dp[i-1][j][k][0][0][0]; for(int p=0;p<=9;p++){ if(p==4) continue; dp[i][k][p][h(j,k,p)][1][0]+=dp[i-1][j][k][0][1][0]; } for(int p=0;p<=9;p++){ if(p==8) continue; dp[i][k][p][h(j,k,p)][2][0]+=dp[i-1][j][k][0][2][0]; } for(int p=0;p<=9;p++) dp[i][k][p][1][f(p)][0]+=dp[i-1][j][k][1][0][0]; for(int p=0;p<=9;p++){ if(p==4) continue; dp[i][k][p][1][1][0]+=dp[i-1][j][k][1][1][0]; } for(int p=0;p<=9;p++){ if(p==8) continue; dp[i][k][p][1][2][0]+=dp[i-1][j][k][1][2][0]; } // < R for(int p=0;p

转载于:https://www.cnblogs.com/katarinayuan/p/6572791.html

你可能感兴趣的文章
InnoDB为什么要使用auto_Increment
查看>>
HDU 1087 Super Jumping! Jumping! Jumping!
查看>>
0007_初始模块和字节码
查看>>
[效率提升]如何管理好你的电脑文件
查看>>
C++实验二
查看>>
使用case语句给字体改变颜色
查看>>
JAVA基础-多线程
查看>>
面试题5:字符串替换空格
查看>>
JSP九大内置对象及四个作用域
查看>>
ConnectionString 属性尚未初始化
查看>>
MySQL基本命令和常用数据库对象
查看>>
poj 1222 EXTENDED LIGHTS OUT(位运算+枚举)
查看>>
进程和线程概念及原理
查看>>
Lucene、ES好文章
查看>>
android 生命周期
查看>>
jquery--this
查看>>
MySQL 5.1参考手册
查看>>
TensorFlow安装流程(GPU加速)
查看>>
OpenStack的容器服务体验
查看>>
BZOJ 1066 蜥蜴(网络流)
查看>>