动态规划:数位DP
数位dp一般应用于:
求出在给定区间[A,B]内,符合条件P(i)的数i的个数
条件P(i)一般与数的大小无关,而与 数的组成 有关
例题是一道BZOJ1833,让求出区间所有整数每个数字出现的次数
递推出f[i][j][k]表示长度为i开头j的所有数字中k的个数
这个东西让我想起了大模拟,高精度
#include<cstdio>
using namespace std;
//a,b 10^12
long long a,b;
long long t[];
struct Data{long long a[];}f[][];
Data operator +(Data a,Data b)
{
Data t;
for(int k=;k<=;k++)
t.a[k]=a.a[k]+b.a[k];
return t;
}
inline long long read()
{
long long x=,f=;char ch=getchar();
while(ch<''||ch>'') {if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<='') {x=x*+ch-'';ch=getchar();}
return x*f;
}
Data cal(long long x)
{
Data ans;for(int i=;i<=;i++) ans.a[i]=;
if(x==)
{
ans.a[]=;
return ans;
}
int len=;
while(t[len]>x) len--;
for(int i=;i<len;i++)
for(int j=;j<=;j++)
ans=ans+f[i][j];
ans.a[]++;
int cur=x/t[len];
for(int i=;i<cur;i++) ans=ans+f[len][i];
x%=t[len];
ans.a[cur]+=x+;
for(int i=len-;i;i--)
{
cur=x/t[i];
for(int j=;j<cur;j++)
ans=ans+f[i][j];
x%=t[i];
ans.a[cur]+=x+;
}
return ans;
}
int main()
{
t[]=;
for(int i=;i<=;i++) t[i]=t[i-]*;
for(int i=;i<=;i++) f[][i].a[i]=;
//初始化
//递推出f[i][j][k]表示长度为i开头j的所有数字中k的个数
for(int i=;i<=;i++) //数字长度
for(int x=;x<=;x++)
for(int y=;y<=;y++)
{
f[i][y]=f[i][y]+f[i-][x];
f[i][y].a[y]+=t[i-];
}
a=read();b=read();
Data t1=cal(b),t2=cal(a-);
for(int i=;i<=;i++)
{
printf("%lld",t1.a[i]-t2.a[i]);
if(i!=) printf(" ");
}
return ;
}
cal函数就是计算从0到当前数中每一个数字出现的次数,对a和b分别求然后作差就好了
挺恶心的一种dp
动态规划:数位DP的更多相关文章
- 动态规划——数位dp
通过先前在<动态规划——背包问题>中关于动态规划的初探,我们其实可以看到,动态规划其实不是像凸包.扩展欧几里得等是具体的算法,而是一种在解决问题中决策的思想.在不同的题目中,我们都需要根据 ...
- 模板 - 动态规划 - 数位dp
#include<bits/stdc++.h> using namespace std; #define ll long long ]; ll dp[][/*可能需要的状态2*/];//不 ...
- 动态规划-数位dp
大佬讲的清楚 [https://blog.csdn.net/wust_zzwh/article/details/52100392] 例子 不要62或4 l到r有多少个数不含62或者4 代码 #incl ...
- 有关动态规划(主要是数位DP)的一点讨论
动态规划(dynamic programming)是运筹学的一个分支,是求解决策过程(decision process)最优化的数学方法.20世纪50年代初美国数学家在研究多阶段决策过程的优化问题时, ...
- 动态规划晋级——HDU 3555 Bomb【数位DP详解】
转载请注明出处:http://blog.csdn.net/a1dark 分析:初学数位DP完全搞不懂.很多时候都是自己花大量时间去找规律.记得上次网络赛有道数位DP.硬是找规律给A了.那时候完全不知数 ...
- 动态规划专题(三)——数位DP
前言 数位\(DP\) 真的是最恶心的\(DP\). 简介 看到那种给你两个数,让你求这两个数之间符合条件的数的个数,且这两个数非常大,这样的题目一般就是 数位\(DP\) 题. 数位\(DP\)一般 ...
- 「动态规划」-数位dp专题
数位dp,今天学长讲的稍玄学,课下花了一会时间仔细看了一下,发现板子是挺好理解的,就在这里写一些: 数位dp主要就是搞一些在区间中,区间内的数满足题目中的条件的数的个数的一类题,题目一般都好理解,这时 ...
- P4317 花神的数论题 动态规划?数位DP
思路:数位$DP$ 提交:5次(其实之前A过,但是调了调当初的程序.本次是2次AC的) 题解: 我们分别求出$sum(x)=i$,对于一个$i$,有几个$x$,然后我们就可以快速幂解决. 至于求个数用 ...
- 数位dp/记忆化搜索
一.引例 #1033 : 交错和 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定一个数 x,设它十进制展从高位到低位上的数位依次是 a0, a1, ..., an ...
随机推荐
- BLE(Bluetooth Low Energy)---first part
原文地址:https://developer.android.com/guide/topics/connectivity/bluetooth-le.html#terms (本人是技术宅,翻译时候,只要 ...
- Python字符串处理:过滤字符串中的英文与符号,保留汉字
使用Python 的re模块,re模块提供了re.sub用于替换字符串中的匹配项. re.sub(pattern, repl, string, count=0) 参数说明: pattern:正则重的模 ...
- javascript对象转为字符串
function getStringTime(time){ //年 year = time.getFullYear(); //月 month = time.getMonth() if(String(m ...
- python简单的数据清洗,数据筛选方法归类
创建数组有两种方式,1.直接赋值 2.随机变量生成随机生成包括4种:np.arange(20),np.linspace(0,10,5),np.logspace(0,2,5),np.random.ran ...
- Remote X11 GUI for Linux/Unix
摘自:https://www.redwireservices.com/remote-x11-for-linux-unix The Problem One of my most feared quest ...
- Hadoop入门案列,初学者Coder
1.WordCount Job类: package com.simope.mr.wcFor; import org.apache.hadoop.conf.Configuration; import o ...
- Unity3d工具方法小集
1.获取垂直水平方向上的输入: float moveHorizontal = Input.GetAxis("Horizontal"); float moveVertical = I ...
- JS 客户端检测
能力检测 能力检测的目标不是识别特定的浏览器,而是识别浏览器的能力. 能力检测需要注意两点: 先检测达成目的的最常用的特性.因为先检测最常用的特性可以保证代码最优化,因为在多数情况下都可以避免测试多个 ...
- 「日常训练」 Mike and Fun (CFR305D2B)
题意(CodeForces 548B) 每次对01矩阵中的一位取反,问每次操作后,单列中最长连续1的长度. 分析 非常非常简单,但是我当时训练的时候WA了四次...无力吐槽了,人间 不值得.jpg 代 ...
- Python如何进行中文注释
最近,由于实习工作的需要,开始接触Python,但是第一个大的脚本写下来之后,连中文注释都没办法加,很郁闷,遂在网上找解决办法,在Python 官网上看到这个页面:http://www.python. ...