递推 dp
工大要建新教学楼了,一座很高很高的楼,它有n层。
学校为了减少排电梯的队伍,建造了好多好多电梯,共有m个。
为了让电梯有序,学校给每个电梯设定了独特的可停楼层,如 x1 x2 y1 y2 表示,x1楼层到x2楼层可停,y1楼层到y2楼层可停。然后其他楼层这个电梯都不停
一天,yanga11ang想去顶层观光,看到了如此多的电梯,不禁一阵眩晕,冒出疑问,如果只坐电梯,该如何去顶楼,有多少种方法可以去顶楼呢?
Ps:电梯只能向上,
Input
第一行一个整数t,表示t组样例,
接下来t组样例
每组样例 第一行两个数 n,m n小于100 ,m小于100
接下来m行 每行四个数 x1,x2,y1,y2 表示电梯停靠楼层 x1<x2<y1<y2
Output
每组样例输出一个整数 表示方法数 (结果对1e9+7取模)
Sample Input 1
2
5 2
1 1 3 3
2 3 5 5
5 1
1 1 2 5
Sample Output 1
1
8
Hint
note: 从一楼坐电梯直接到三楼,和坐这部电梯先到二楼下电梯再上这部电梯最终到达三楼,被考虑为是不同的方案
题目分析 : 有 m 个长度为 n 的电梯,不同电梯可以停靠的楼层不同,就是一个递推式的 dp, 首先比如对于第 3 层来学,总的方案数就是到第一层的方案数乘以 第一层到第三层的方案总数 + 第二层到第三层的方案数
代码示例 :
#define ll long long
const ll eps = 1e9+7; int n, m; int mp[105][105];
ll dp[105];
ll f[105]; int main() {
freopen("1.in", "r", stdin);
int t;
int x1, y1, x2, y2; cin >> t;
while(t--){
scanf("%d%d", &n, &m);
memset(mp, 0, sizeof(mp));
int sign = 0;
for(int i = 1; i <= m; i++){
scanf("%d%d%d%d", &x1, &y1, &x2, &y2);
for(int j = x1; j <= y1; j++){
mp[i][j] = 1;
if (j == 1) sign = 1;
}
for(int j = x2; j <= y2; j++){
mp[i][j] = 1;
if (j == 1) sign = 1;
}
}
memset(dp, 0, sizeof(dp));
if (sign) dp[1] = 1ll;
else {
printf("0\n");
continue;
} for(int i = 2; i <= n; i++){
for(int j = i-1; j >= 1; j--){
ll cnt = 0;
for(int k = 1; k <= m; k++){
if (mp[k][i] && mp[k][j]) cnt++;
}
dp[i] += ((dp[j]%eps)*(cnt%eps))%eps;
dp[i] %= eps;
}
}
printf("%lld\n", dp[n]%eps);
} return 0;
}
递推 dp的更多相关文章
- 递推DP URAL 1167 Bicolored Horses
题目传送门 题意:k个马棚,n条马,黑马1, 白马0,每个马棚unhappy指数:黑马数*白马数,问最小的unhappy值是多少分析:dp[i][j] 表示第i个马棚放j只马的最小unhappy值,状 ...
- 递推DP URAL 1017 Staircases
题目传送门 /* 题意:给n块砖头,问能组成多少个楼梯,楼梯至少两层,且每层至少一块砖头,层与层之间数目不能相等! 递推DP:dp[i][j] 表示总共i块砖头,最后一列的砖头数是j块的方案数 状态转 ...
- 递推DP URAL 1260 Nudnik Photographer
题目传送门 /* 递推DP: dp[i] 表示放i的方案数,最后累加前n-2的数字的方案数 */ #include <cstdio> #include <algorithm> ...
- 递推DP URAL 1353 Milliard Vasya's Function
题目传送门 /* 题意:1~1e9的数字里,各个位数数字相加和为s的个数 递推DP:dp[i][j] 表示i位数字,当前数字和为j的个数 状态转移方程:dp[i][j] += dp[i-1][j-k] ...
- 递推DP URAL 1119 Metro
题目传送门 /* 题意:已知起点(1,1),终点(n,m):从一个点水平或垂直走到相邻的点距离+1,还有k个抄近道的对角线+sqrt (2.0): 递推DP:仿照JayYe,处理的很巧妙,学习:) 好 ...
- 递推DP 赛码 1005 Game
题目传送门 /* 递推DP:官方题解 令Fi,j代表剩下i个人时,若BrotherK的位置是1,那么位置为j的人是否可能获胜 转移的时候可以枚举当前轮指定的数是什么,那么就可以计算出当前位置j的人在剩 ...
- 递推DP HDOJ 5328 Problem Killer
题目传送门 /* 递推DP: 如果a, b, c是等差数列,且b, c, d是等差数列,那么a, b, c, d是等差数列,等比数列同理 判断ai-2, ai-1, ai是否是等差(比)数列,能在O( ...
- hdu1978(递推dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1978 分析: 递推DP. dp[][]表示可以到达改点的方法数. 刚开始:外循环扫描所有点dp[x][ ...
- 递推DP URAL 1031 Railway Tickets
题目传送门 /* 简单递推DP:读题烦!在区间内的都更新一遍,dp[]初始化INF 注意:s1与s2大小不一定,坑! 详细解释:http://blog.csdn.net/kk303/article/d ...
- 递推DP UVA 607 Scheduling Lectures
题目传送门 题意:教授给学生上课,有n个主题,每个主题有ti时间,上课有两个限制:1. 每个主题只能在一节课内讲完,不能分开在多节课:2. 必须按主题顺序讲,不能打乱.一节课L时间,如果提前下课了,按 ...
随机推荐
- maven环境隔离
pom <build>节点下增加节点 <resources> <resource> <directory> src/main/resources.${d ...
- JAVA核心知识点--打包 FatJar 方法小结
目录 什么是 FatJar 三种打包方法 1. 非遮蔽方法(Unshaded) 2. 遮蔽方法(Shaded) 3. 嵌套方法(Jar of Jars) 小结 参考阅读 原文地址:https://yq ...
- WPF 元素裁剪 Clip 属性
本文介绍如何在 WPF 使用 Clip 裁剪元素 在 WPF 的 UIElement 提供了 Clip 属性,这个属性默认是空,但是如果设置了这个属性就会对元素进行裁剪 这个属性是一个 Geometr ...
- SVG基础绘图实例
SVG可缩放矢量图(Scalable Vector Graphics),是使用 XML 来描述二维图形和绘图程序的语言,图像在放大或改变尺寸的情况下其图形质量不会有所损失,是万维网联盟的标准. 下面整 ...
- 2018-2-13-win10-uwp-从Type使用构造
title author date CreateTime categories win10 uwp 从Type使用构造 lindexi 2018-2-13 17:23:3 +0800 2018-2-1 ...
- 【53.57%】【codeforces 610C】Harmony Analysis
time limit per test3 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- Android studio 使用git仓库记录
studio 绑定git settings --> verson control -->git 在项目文件目录右击打开git bash here操作界面 查看git项目安装位置 找到id_ ...
- Python 实现栈与队列
#基于Python2.7 #基于顺序表实现 #发现用Python写题时,没有像写C++时方便的STL可用,不过查阅资料之后发现用class实现也很简洁,不过效率应该不是很高 Python实现栈并使用: ...
- 以windows服务方式快速部署免安装版Postgres数据库
目录 以windows服务方式快速部署免安装版Postgres数据库 1.下载Postgresql数据库免安装包 2.安装环境准备及验证 解压文件 测试环境依赖 3.创建并初始化数据目录 创建数据目录 ...
- window10 自带虚拟机输入ip addr 不显示ip,显示字母加数字
\(\color{Black}{文/魂皓轩}\) 1.在界面输入ip addr 2.通过ls 查看当前文件 我的虚拟机网络配置文件为ifcfg-eth0(不同主机文件名不一样) 3.通过 vi ifc ...