【学习笔记&训练记录】数位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 ...
随机推荐
- C#中excel导入sql
using Microsoft.Office.Interop.Excel; public int ledinExcel(string file, object sender, EventArgs e) ...
- myeclipse 8.5离线安装python插件
看到网上很多教程扯了一大堆,好麻烦的样子. 1)下载pyhon开发插件,PyDev 2.2.0.zip 我在百度137708820网盘里已分享,链接http://pan.baidu.com/s/1mg ...
- 表单验证——JavaScript和Jquery版
1.轻量级的JavaScript表单验证 在应用中引用 validator.min.js 文件 <script type="text/javascript" src=&quo ...
- [py]给函数传递数组和字典
一 , 1.1传元组 def fun(x): print x t=(1,2) fun(t) 1.2传元组 #传元组 def fun(x,y): print x,y # t=(1,2) t=(1,2,3 ...
- 《深入理解Bootstrap》勘误
感谢大家 感谢大家仔细阅读本书,并给本书指出了那么多的错误,下次重印时,一定会修正. 勘误列表 ID 发行人 章节 原文 更新文 备注 1 剑衣清风(微博) 1.5选择器(p7) [att$=valu ...
- left join 条件区别
t1: num | name-----+------ 1 | a 2 | b 3 | c t2: num | value-----+------- 1 | xxx 3 ...
- 基于DDD的.NET开发框架 - ABP仓储实现
返回ABP系列 ABP是“ASP.NET Boilerplate Project (ASP.NET样板项目)”的简称. ASP.NET Boilerplate是一个用最佳实践和流行技术开发现代WEB应 ...
- node 学习笔记 - Modules 模块加载系统 (2)
本文同步自我的个人博客:http://www.52cik.com/2015/12/14/learn-node-modules-module.html 上一篇讲了模块是如何被寻找到然后加载进来的,这篇则 ...
- 深入理解 cocos2d-x 坐标系
首先对于初学的,带大家认识 cocos2d-x 中坐标系的几个概念,参考 http://blog.csdn.net/tskyfree/article/details/8292544.其他的往下看. 弄 ...
- 继续研究NDK
继续研究NDK 我在阿里云服务器上搭建了Android ndk的开发平台,并且借助这一平台研究了NDK的内部细节. NDK提供了Android本地编程的接口,让你可以开发高效的依赖库,提高程序的速度, ...