工大要建新教学楼了,一座很高很高的楼,它有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

  1. 2
  2. 5 2
  3. 1 1 3 3
  4. 2 3 5 5
  5. 5 1
  6. 1 1 2 5

Sample Output 1

  1. 1
  2. 8

Hint

note: 从一楼坐电梯直接到三楼,和坐这部电梯先到二楼下电梯再上这部电梯最终到达三楼,被考虑为是不同的方案

题目分析 : 有 m 个长度为 n 的电梯,不同电梯可以停靠的楼层不同,就是一个递推式的 dp, 首先比如对于第 3 层来学,总的方案数就是到第一层的方案数乘以 第一层到第三层的方案总数 + 第二层到第三层的方案数

代码示例 :

  1. #define ll long long
  2. const ll eps = 1e9+7;
  3.  
  4. int n, m;
  5.  
  6. int mp[105][105];
  7. ll dp[105];
  8. ll f[105];
  9.  
  10. int main() {
  11. freopen("1.in", "r", stdin);
  12. int t;
  13. int x1, y1, x2, y2;
  14.  
  15. cin >> t;
  16. while(t--){
  17. scanf("%d%d", &n, &m);
  18. memset(mp, 0, sizeof(mp));
  19. int sign = 0;
  20. for(int i = 1; i <= m; i++){
  21. scanf("%d%d%d%d", &x1, &y1, &x2, &y2);
  22. for(int j = x1; j <= y1; j++){
  23. mp[i][j] = 1;
  24. if (j == 1) sign = 1;
  25. }
  26. for(int j = x2; j <= y2; j++){
  27. mp[i][j] = 1;
  28. if (j == 1) sign = 1;
  29. }
  30. }
  31. memset(dp, 0, sizeof(dp));
  32. if (sign) dp[1] = 1ll;
  33. else {
  34. printf("0\n");
  35. continue;
  36. }
  37.  
  38. for(int i = 2; i <= n; i++){
  39. for(int j = i-1; j >= 1; j--){
  40. ll cnt = 0;
  41. for(int k = 1; k <= m; k++){
  42. if (mp[k][i] && mp[k][j]) cnt++;
  43. }
  44. dp[i] += ((dp[j]%eps)*(cnt%eps))%eps;
  45. dp[i] %= eps;
  46. }
  47. }
  48. printf("%lld\n", dp[n]%eps);
  49. }
  50.  
  51. return 0;
  52. }

递推 dp的更多相关文章

  1. 递推DP URAL 1167 Bicolored Horses

    题目传送门 题意:k个马棚,n条马,黑马1, 白马0,每个马棚unhappy指数:黑马数*白马数,问最小的unhappy值是多少分析:dp[i][j] 表示第i个马棚放j只马的最小unhappy值,状 ...

  2. 递推DP URAL 1017 Staircases

    题目传送门 /* 题意:给n块砖头,问能组成多少个楼梯,楼梯至少两层,且每层至少一块砖头,层与层之间数目不能相等! 递推DP:dp[i][j] 表示总共i块砖头,最后一列的砖头数是j块的方案数 状态转 ...

  3. 递推DP URAL 1260 Nudnik Photographer

    题目传送门 /* 递推DP: dp[i] 表示放i的方案数,最后累加前n-2的数字的方案数 */ #include <cstdio> #include <algorithm> ...

  4. 递推DP URAL 1353 Milliard Vasya's Function

    题目传送门 /* 题意:1~1e9的数字里,各个位数数字相加和为s的个数 递推DP:dp[i][j] 表示i位数字,当前数字和为j的个数 状态转移方程:dp[i][j] += dp[i-1][j-k] ...

  5. 递推DP URAL 1119 Metro

    题目传送门 /* 题意:已知起点(1,1),终点(n,m):从一个点水平或垂直走到相邻的点距离+1,还有k个抄近道的对角线+sqrt (2.0): 递推DP:仿照JayYe,处理的很巧妙,学习:) 好 ...

  6. 递推DP 赛码 1005 Game

    题目传送门 /* 递推DP:官方题解 令Fi,j代表剩下i个人时,若BrotherK的位置是1,那么位置为j的人是否可能获胜 转移的时候可以枚举当前轮指定的数是什么,那么就可以计算出当前位置j的人在剩 ...

  7. 递推DP HDOJ 5328 Problem Killer

    题目传送门 /* 递推DP: 如果a, b, c是等差数列,且b, c, d是等差数列,那么a, b, c, d是等差数列,等比数列同理 判断ai-2, ai-1, ai是否是等差(比)数列,能在O( ...

  8. hdu1978(递推dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1978 分析: 递推DP. dp[][]表示可以到达改点的方法数. 刚开始:外循环扫描所有点dp[x][ ...

  9. 递推DP URAL 1031 Railway Tickets

    题目传送门 /* 简单递推DP:读题烦!在区间内的都更新一遍,dp[]初始化INF 注意:s1与s2大小不一定,坑! 详细解释:http://blog.csdn.net/kk303/article/d ...

  10. 递推DP UVA 607 Scheduling Lectures

    题目传送门 题意:教授给学生上课,有n个主题,每个主题有ti时间,上课有两个限制:1. 每个主题只能在一节课内讲完,不能分开在多节课:2. 必须按主题顺序讲,不能打乱.一节课L时间,如果提前下课了,按 ...

随机推荐

  1. 2018-8-10-C#-代码占用的空间

    title author date CreateTime categories C# 代码占用的空间 lindexi 2018-08-10 19:16:52 +0800 2018-2-13 17:23 ...

  2. java 利用Class获取类的属性信息

    package junereflect624; import java.lang.reflect.Modifier; class A { } interface B{ } interface C{ } ...

  3. linux加载和卸载模块

    模块建立之后, 下一步是加载到内核. 如我们已指出的, insmod 为你完成这个工作. 这个 程序加载模块的代码段和数据段到内核, 接着, 执行一个类似 ld 的函数, 它连接模块中 任何未解决的符 ...

  4. The Function() Constructor

    Functions are usually defined using the function keyword, either in the form of a function definitio ...

  5. vue面试的一些总结

    vue中组件的data为什么是一个函数? 组件是可复用的vue实例,一个组件被创建好之后,就可能被用在各个地方,而组件不管被复用了多少次,组件中的data数据都应该是相互隔离,互不影响的,基于这一理念 ...

  6. SAPI(PHP常见的四种运行模式)

    SAPI(Server Application Programming Interface)服务器应用程序编程接口,即PHP与其他应用交互的接口,PHP脚本要执行有很多方式,通过Web服务器,或者直接 ...

  7. JQuery多个异步操作后执行(resolve,promise,when,done)

    代码分享: //3秒后完成 function asyncThing1() { var dfd = $.Deferred(); setTimeout(function () { alert('async ...

  8. lnmp一键安装,安装php时失败

    查看安装日志 直接cd进入根目录报错内容:configure: error: mcrypt.h not found. Please reinstall libmcrypt 解决办法如下#使用wget可 ...

  9. Dubbo-本地测试直连

    一.服务提供方 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http: ...

  10. requests爬取豆瓣top250电影信息

    ''' 1.爬取豆瓣top250电影信息 - 第一页: https://movie.douban.com/top250?start=0&filter= - 第二页: https://movie ...