【学习笔记&训练记录】数位DP
数位DP,即对数位进行拆分,利用数位来转移的一种DP,一般采用记忆化搜索,或者是先预处理再进行转移
一个比较大略的思想就是可以对于给定的大数,进行按数位进行固定来转移记录答案
区间类型的,可以考虑前缀和的思想,求[l,r]可以看做求[1,r]-[1,l)
其实还有一种,是按照二进制建一颗0,1树来表示,来做,但是比并没有做过,以后再总结
HDU-2089
题目大意:对于区间[L,R]求有多少不包含'62'且不包含'4'的数,题目允许有前导零
思路:
数位DP,考虑F[i][j]表示位数为i,最高位为j的满足的个数
预处理后,统计答案即可,统计答案大致就是固定每一位,进行统计
CODE:
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
using namespace std;
int read()
{
int x=,f=; char ch=getchar();
while (ch<'' || ch>'') {if (ch=='-') f=-; ch=getchar();}
while (ch>='' && ch<='') {x=x*+ch-''; ch=getchar();}
return x*f;
}
int n,m;
int F[][];
void prework()
{
F[][]=;
for (int i=; i<=; i++)
for (int j=; j<=; j++)
for (int k=; k<=; k++)
if (j!= && !(j==&&k==))
F[i][j]+=F[i-][k];
}
int Calc(int x)
{
int digit[]={},len=,ans=;
while (x!=) {digit[++len]=x%; x/=;}
for (int i=len; i>=; i--)
{
for (int j=; j<=digit[i]-; j++)
if (j!= && !(j==&&digit[i+]==))
ans+=F[i][j];
if (digit[i]== || (digit[i]==&&digit[i+]==)) break;
}
return ans;
}
int main()
{
prework();
n=read(),m=read(); if (n>m) swap(n,m);
while (n!= && m!=)
{
printf("%d\n",Calc(m+)-Calc(n));
n=read(),m=read(); if (n>m) swap(n,m);
}
return ;
}
HDU-3652
题目大意:给定n,求到n中,包含'13'且被13整除的数的个数
思路:
设计状态F[i][j][k][0/1]表示位数为i,最高位为j的%13余k的数字包含和不包含13的个数
那么同样预处理,这里不含前导零,需要额外做一个值去进行计算,计算到n以内的,计算n+1即可
CODE:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
using namespace std;
long long n;
long long F[][][][];
long long cf(int x,int y)
{
long long re=x;
for (int i=; i<y; i++) re*=;
return re;
}
void prework()
{
for (int i=; i<=; i++) F[][i][i%][]=;
for (int i=; i<=; i++)
for (int tmp,j=; j<=; j++)
{
tmp=cf(j,i-);
for (int k=; k<=; k++)
for (int l=; l<; l++)
{
F[i][j][(tmp+l)%][]+=F[i-][k][l][];
if (j== && k==)
F[i][j][(tmp+l)%][]+=F[i-][k][l][];
else
F[i][j][(tmp+l)%][]+=F[i-][k][l][];
}
}
// for (int i=1; i<=10; i++)
// for (int j=0; j<=9; j++)
// for (int k=0; k<13; k++)
// printf("%I64d %I64d\n",F[i][j][k][1],F[i][j][k][0]);
}
long long Calc(long long x)
{
int digit[]={},len=,f=; long long ans=;
while (x) {digit[++len]=x%; x/=;}
for (int i=; i<=digit[len]-; i++)
ans+=F[len][i][][];
long long tmp=cf(digit[len],len-);
for (int tt,i=len-; i>=; i--)
{
for (int j=; j<=digit[i]-; j++)
for (int k=; k<; k++)
{
if ((tmp+k)%==) ans+=F[i][j][k][];
if ((tmp+k)%== && (digit[i+]== && j==))
ans+=F[i][j][k][];
else if ((tmp+k)%== && f) ans+=F[i][j][k][];
}
if (digit[i]== && digit[i+]==) f=;
tmp+=cf(digit[i],i-);
}
return ans;
}
int main()
{
prework();
while (scanf("%lld",&n)!=EOF)
printf("%lld\n",Calc(n+));
return ;
}
【学习笔记&训练记录】数位DP的更多相关文章
- 「学习笔记」wqs二分/dp凸优化
[学习笔记]wqs二分/DP凸优化 从一个经典问题谈起: 有一个长度为 \(n\) 的序列 \(a\),要求找出恰好 \(k\) 个不相交的连续子序列,使得这 \(k\) 个序列的和最大 \(1 \l ...
- 【学习笔记】动态规划—各种 DP 优化
[学习笔记]动态规划-各种 DP 优化 [大前言] 个人认为贪心,\(dp\) 是最难的,每次遇到题完全不知道该怎么办,看了题解后又瞬间恍然大悟(TAT).这篇文章也是花了我差不多一个月时间才全部完成 ...
- 汇编入门学习笔记 (七)—— dp,div,dup
疯狂的暑假学习之 汇编入门学习笔记 (七)-- dp.div.dup 參考: <汇编语言> 王爽 第8章 1. bx.si.di.和 bp 8086CPU仅仅有4个寄存器能够用 &qu ...
- 专题训练之数位DP
推荐以下一篇博客:https://blog.csdn.net/wust_zzwh/article/details/52100392 1.(HDOJ2089)http://acm.hdu.edu.cn/ ...
- 2019年9月训练(壹)数位DP (HDU 2089)
开学之后完全没时间写博客.... HDU 2089 不要62(vjudge) 数位DP 思路: 题目给出区间[n,m] ,找出不含4或62的数的个数 用一个简单的差分:先求0~m+1的个数,再减去0~ ...
- [学习笔记]搜索——模拟与dp的结合
搜索: 一种基础的算法. 考察常见于NOIP 但是高级的搜索算法可能还会在省选出现. 50%以上的暴力都可以用搜索直接枚举来写. 但是,当数据规模不是很大的时候,搜索也可能成为正解. (比如剪枝PK状 ...
- 洛谷4719 【模板】动态dp 学习笔记(ddp 动态dp)
qwq大概是混乱的一个题. 首先,还是从一个比较基础的想法开始想起. 如果每次暴力修改的话,那么每次就可以暴力树形dp 令\(dp[x][0/1]\)表示\(x\)的子树中,是否选择\(x\)这个点的 ...
- 「学习笔记」斜率优化dp
目录 算法 例题 任务安排 题意 思路 代码 [SDOI2012]任务安排 题意 思路 代码 任务安排 再改 题意 思路 练习题 [HNOI2008]玩具装箱 思路 代码 [APIO2010]特别行动 ...
- [学习笔记]四边形不等式优化DP
形如$f[i][j]=min{f[i][k]+f[k+1][j]}+w[i][j]$的方程中, $w[\;][\;]$如果同时满足: ①四边形不等式:$w[a][c]+w[b][d]\;\leq\;w ...
随机推荐
- ATI显卡添加自定义分辨率
run regedit, 浏览到这个键目录下 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Video 先导出一个作为备份. 查找 DALNo ...
- usb驱动开发18之设备生命线
现在已经使用GET_DESCRIPTOR请求取到了包含一个配置里所有相关描述符内容的一堆数据,这些数据是raw的,即原始的,所有数据不管是配置描述符.接口描述符还是端点描述符都挤在一起,所以得想办法将 ...
- Windows 8.1 新增控件之 TimePicker
之前已经为大家介绍过DatePicker 控件的相关内容,有日期控件当然就得有时间控件,本篇将和各位一起了解TimePicker 的使用方法. 先来介绍一下ClockIdentifier 属性,默认情 ...
- C# 多重overide
overide 是覆盖的意思,用在且仅用在虚函数上,虚函数可以是virtual或abstract修饰的,或者是overide修饰的. 文档大概是这么说的. 由此知道,由overide修饰的函数都是虚函 ...
- 离线安装 Cloudera ( CDH 5.x )
要配置生产环境前,最好严格按照官方文档/说明配置环境.比如,官方说这个安装包用于RETHAT6, CENTOS6,那就要装到6的版本下,不然很容易出现各种各样的错. 配置这个CDH5我入了很多坑,最重 ...
- ZH奶酪:Java调用NLPIR汉语分词系统
NLPIR工具 支持自定义词表: 可以离线使用: 下载地址:http://ictclas.nlpir.org/newsdownloads?DocId=389 在线演示:http://ictclas.n ...
- Hashtable Dictionary List 谁效率更高
一 前言 很少接触HashTable晚上回来简单看了看,然后做一些增加和移除的操作,就想和List 与 Dictionary比较下存数据与取数据的差距,然后便有了如下的一此测试, 当然我测的方法可能不 ...
- Github优秀java项目集合(中文版) - 涉及java所有的知识体系
Java资源大全中文版 我想很多程序员应该记得 GitHub 上有一个 Awesome - XXX 系列的资源整理.awesome-java 就是 akullpp 发起维护的 Java 资源列表,内容 ...
- 开源:ASP.NET MVC+EF6+Bootstrap开发框架
前言 我在博客园潜水两三年了,在这里看过很多大神的文章,也学到了很多东西.可以说我是汲取着博客园的营养成长的. 想当年,我也是拿10个G的精神粮食从一个博客园大神那里换来一套开发框架,正式走上开发之路 ...
- 备忘:hibernate, logback, slf4j实际应用一例
用hibernate写一些简单的数据库的Java应用.主要是温习一下.之前弄过的一些都忘了.发现还是得记下来,不然很快就忘. 1. Eclipse版本,用Juno, J2EE版本.最好下载zip版本的 ...