最近学习了一下数位DP

感觉记忆化搜索是比较好理解的

这篇博客对我有一定的启发https://www.cnblogs.com/zbtrs/p/6106783.html

总结了一下:
 
 用数位DP的题目:
 
 形如“问在x到y的整数中满足性质……的数的个数”
 
套路:
main函数一般是这样的
 
 

设max为上限值,即我们要统计 max之前的满足性质的数的个数
为了使搜到的数都满足 x<max
 所以我们在搜索时定义一个bool型变量shangxian,表示搜到当前数位时前面的数位是否是沿着上限值
 例如:上限max为54123
 第一位时shangxian=true 搜0,1,2,3,4,5
 若第一位搜到了0,1,2,3,4,下一位shangxian=false
 若第一位搜到了5,下一位shangxian=true
 若shangxian=false 该位枚举0~9,且向下递归时shangxian一直为false
 若shangxian=true  该位枚举0~max[i],当该位搜到max[i]时,下一位shangxian=true,否则
 Shangxian=false

windy数

显然这是一道数位DP的题

要注意的地方是前导全零时的状态转移

 #include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
#define abs(i) ((i)>0?(i):(-i))
int a,b,maxx[],dp[][];  //dp[i][j]前i位 第i-1位是j的方案数
int dfs(int len,int lastnum,bool shangxian,bool O){
if(len==) return O^;
if(!shangxian&&dp[len][lastnum])
return dp[len][lastnum];
int cnt=,M=shangxian?maxx[len]:;
for(int i=;i<=M;i++){
if(!O&&abs(lastnum-i)<) continue;    //前面都是前导0,该位不受其限制
cnt+=dfs(len-,i,shangxian&&i==M,O&&i==);
}
if(!shangxian&&!O) dp[len][lastnum]=cnt;  //前面都是前导0,不会限制到下一位,不能记忆化
return cnt;
}
int solve(int x){
memset(maxx,,sizeof(maxx));
memset(dp,,sizeof(dp));    //注意要清空数组
int k=;
while(x){
maxx[++k]=x%;
x/=;
}
return dfs(k,-,,);
}
int main()
{
scanf("%d%d",&a,&b);
printf("%d",solve(b)-solve(a-));
return ;
}

【洛谷P2657】[SCOI2009] windy数的更多相关文章

  1. 洛谷 P2657 [SCOI2009]windy数 解题报告

    P2657 [SCOI2009]windy数 题目描述 \(\tt{windy}\)定义了一种\(\tt{windy}\)数.不含前导零且相邻两个数字之差至少为\(2\)的正整数被称为\(\tt{wi ...

  2. 洛谷——P2657 [SCOI2009]windy数

    P2657 [SCOI2009]windy数 题目大意: windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道, 在A和B之间,包括A和 ...

  3. C++ 洛谷 P2657 [SCOI2009]windy数 题解

    P2657 [SCOI2009]windy数 同步数位DP 这题还是很简单的啦(差点没做出来 个位打表大佬请离开(包括记搜),我这里讲的是DP!!! 首先Cal(b+1)-Cal(a),大家都懂吧(算 ...

  4. 洛谷P2657 [SCOI2009]windy数 [数位DP,记忆化搜索]

    题目传送门 windy数 题目描述 windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道, 在A和B之间,包括A和B,总共有多少个win ...

  5. [洛谷P2657][SCOI2009]windy数

    题目大意:不含前导零且相邻两个数字之差至少为$2$的正整数被称为$windy$数.问$[A, B]$内有多少个$windy$数? 题解:$f_{i, j}$表示数有$i$位,最高位为$j$(可能为$0 ...

  6. 洛谷P2657 [SCOI2009]windy数 题解 数位DP

    题目链接:https://www.luogu.com.cn/problem/P2657 题目大意:找区间 \([A,B]\) 范围内 不含前导零 且 相邻两个数字之差至少为2 的正整数的个数. 题目分 ...

  7. 洛谷 P2657 [SCOI2009]windy数

    题意简述 求l~r之间不含前导零且相邻两个数字之差至少为2的正整数的个数 题解思路 数位DP 代码 #include <cstdio> #include <cstring> # ...

  8. BZOJ1026或洛谷2657 [SCOI2009]windy数

    BZOJ原题链接 洛谷原题链接 简单的数位\(DP\),套模板就好. #include<cstdio> #include<cstring> using namespace st ...

  9. luogu P2657 [SCOI2009]windy数 数位dp 记忆化搜索

    题目链接 luogu P2657 [SCOI2009]windy数 题解 我有了一种所有数位dp都能用记忆话搜索水的错觉 代码 #include<cstdio> #include<a ...

  10. P2657 [SCOI2009]windy数

    P2657 [SCOI2009]windy数 题目描述 windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道, 在A和B之间,包括A和B ...

随机推荐

  1. 重拾简单的linux指令之info 【转】

    info命令 可以利用该命令获取帮助 1. 语法格式:info <command> 2. 语法简述: 类似于man命令的获取帮助信息,比较于man命令更容易读.是以网页的结构来显示内容.而 ...

  2. angular的基本要点

    <body ng-app="Myapp"> <div ng-controller="firstcon"> <h1>hello ...

  3. TOJ 4523 Transportation

    Description Given N stations, you want to carry goods from station 1 to station N. Among these stati ...

  4. poi 多行合并

    poi做多行合并,一定需要先绘制单元格,然后写入数据,最后合并,不然各种坑啊. 合并单元格所使用的方法: sheet.addMergedRegion( CellRangeAddress  cellRa ...

  5. php中的$_GET如何获取带有“#”的参数

    <?php echo $_GET['key']; ?> 当url为http://test.com/c.php?key=999时,正常输出:999 当url为http://test.com/ ...

  6. BNU27935——我爱背单词——————【数组模拟】

    我爱背单词 Time Limit: 1000ms Memory Limit: 65536KB 64-bit integer IO format: %lld      Java class name:  ...

  7. SpringBoot | 第三十一章:MongoDB的集成和使用

    前言 上一章节,简单讲解了如何集成Spring-data-jpa.本章节,我们来看看如何集成NoSQL的Mongodb.mongodb是最早热门非关系数据库的之一,使用也比较普遍.最适合来存储一些非结 ...

  8. (一)安装Python

    一.安装python 打开 Python官网,找到“Download”, 在其下拉菜单中选择自己的平台(Windows/Mac),一般的Linux平台已经自带的Python,所以不需要安装,通过打开“ ...

  9. node.js发邮件

    在node上使用第三方类库(nodemailer)发邮件是一件很esay的事情:) app.js   以QQ邮箱为例 var nodemailer = require('nodemailer'); v ...

  10. oracle学习篇七:更新操作、事务处理

    ----------------1.数据库更新操作----------------------------- select * from tab;--查询表 drop table siebel_use ...