HDU 5794:A Simple Chess(Lucas + DP)

题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=5794

题意:让一个棋子从(1,1)走到(n,m),要求像马一样走日字型并只能往右下角走。里面还有r个障碍点不能经过或者到达,问有多少种走法可以走到(n,m)。

思路:画个图可以发现走的点像一个斜着的杨辉三角。所以可以得到一个从点 i 走到点 j 的路径数是一个组合数。 

大概就是长这样,杨辉三角的每个点的数如下。

1

      1

1      2      1

1       3      3      1

1      4       6      4      1

1       5      10      10      5      1

1      6      15      20      15      6      1

1      7      21      35      35      21      7      1

 

找到规律:路径数为C(在这一步的位置,走过的步数)。走过的步数是当前的点 i 坐标(x,y),(x+y)/3就是步数了。当前的位置是min(x,y)-步数。这里的步数就相当于三角的层数。

首先对全部障碍从小到大进行排序,对于每个障碍 i,求出从(1,1)走到其的路径总数,减去之前的障碍(0 <= j < i)可以走到现在的障碍的路径总数(dp[i] -= dp[j] * 从点 j 走到点 i 的路径数)。组合数的计算要用到Lucas定理进行计算。

  1 #include <cstdio>
  2 #include <cstring>
  3 #include <algorithm>
  4 #include <string>
  5 #include <cmath>
  6 #include <iostream>
  7 #include <stack>
  8 using namespace std;
  9 #define MOD 110119
 10 typedef long long LL;
 11 struct node
 12 {
 13     LL x, y;
 14 }p[115];
 15 LL dp[115];
 16 LL f[MOD+10];
 17 /*
 18 dp[i]一开始表示从(0, 0)走到第i个点的路径数
 19 后面要减去如果前面有障碍,那么会有一部分路径是不能走的
 20 减去的路径数为分别为第j个点(0<=j<i)走到第i个点的路径数*dp[j]
 21 */
 22 
 23 bool cmp(const node &a, const node &b)
 24 {
 25     if(a.x == b.x) return a.y < b.y;
 26     return a.x < b.x;
 27 }
 28 
 29 void biao() //打出阶乘表
 30 {
 31     f[0] = f[1] = 1;
 32     for(int i = 2; i <= MOD; i++) {
 33         f[i] = f[i-1] * i % MOD;
 34     }
 35 }
 36 
 37 LL quick_pow(LL a, LL b)
 38 {
 39     a %= MOD, b %= MOD;
 40     LL ans = 1;
 41     while(b) {
 42         if(b & 1) ans = ans * a % MOD;
 43         a = a * a % MOD;
 44         b >>= 1;
 45     }
 46     return ans;
 47 }
 48 
 49 LL C(LL n, LL m)
 50 {
 51     if(m > n) return 0;
 52     if(m < 0) return 0;
 53     LL ans = 1;
 54     ans = ans * f[n] % MOD * quick_pow(f[m] * f[n-m] % MOD, MOD - 2) % MOD;
 55     return ans;
 56 }
 57 
 58 LL Lucas(LL n, LL m)
 59 {
 60     if(m == 0) return 1;
 61     return C(n % MOD, m % MOD) % MOD * Lucas(n / MOD, m / MOD) % MOD;
 62 }
 63 
 64 int main()
 65 {
 66     LL n, m, r;
 67     int cas = 0;
 68     biao();
 69     while(~scanf("%I64d%I64d%I64d", &n, &m, &r)) {
 70         memset(dp, 0, sizeof(dp));
 71         bool flag = 0;
 72         for(int i = 0; i < r; i++) {
 73             scanf("%I64d%I64d", &p[i].x, &p[i].y);
 74             if(p[i].x == n && p[i].y == m) flag = 1;
 75             p[i].x--, p[i].y--;
 76         }
 77         sort(p, p + r, cmp);
 78         p[r].x = n - 1, p[r].y = m - 1; //把目标点加入
 79         printf("Case #%d: ", ++cas);
 80         if(flag || (p[r].x + p[r].y) % 3 != 0) { //如果障碍在目标点上或者不能走到目标点
 81             puts("0"); continue;
 82         }
 83         for(int i = 0; i <= r; i++) {
 84             if((p[i].x + p[i].y) % 3 == 0) { //如果这个障碍是可以走到的
 85                 LL a = (p[i].x + p[i].y) / 3; //第几层
 86                 LL b = min(p[i].x, p[i].y) - a; //位置
 87                 dp[i] = Lucas(a, b); //类似于杨辉三角的组合数
 88                 for(int j = 0; j < i; j++) {
 89                     if(p[j].y >= p[i].y || p[j].x >= p[i].x) continue; //题目要求只能往右下角走
 90                     LL xx = (p[i].x - p[j].x);
 91                     LL yy = (p[i].y - p[j].y);
 92                     if((xx + yy) % 3 == 0) { //要能够从j点走到i点
 93                         LL aa = (xx + yy) / 3;
 94                         LL bb = min(xx, yy) - aa; //减去可以从j点走到i点的路径数
 95                         dp[i] -= (Lucas(aa, bb) * dp[j]) % MOD;
 96                         dp[i] = (dp[i] + MOD) % MOD;
 97                     }
 98                 }
 99             }
100         }
101         printf("%I64d\n", dp[r]);
102     }
103     return 0;
104 }

 

转载于:https://www.cnblogs.com/fightfordream/p/5827815.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/373994.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php源码分析之PHPAPI宏的作用

在PHP源码中&#xff0c;我们经常会看到很多函数前面有个PHPAPI&#xff0c;但这是什么呢&#xff1f; 于是我在php源码/main/php.h中找到了它的定义 #ifdef PHP_WIN32 # include "tsrm_win32.h" # include "win95nt.h" # ifdef PHP_EXPORTS # …

15分钟内开始使用Amazon Web Services和全自动资源调配

在等待一个新项目时&#xff0c;我想学习一些有用的东西。 而且由于在许多项目中我们需要评估和测试正在开发的应用程序的性能&#xff0c;而很少有足够的硬件来生成实际负载&#xff0c;因此我决定学习更多有关按需在云中按需配置虚拟机的知识&#xff0c;即Amazon Web Servic…

解析JVM内存区域组成

在方法&#xff08;代码块&#xff09;中定义一个变量时&#xff0c;java就在栈中为这个变量分配JVM内存空间&#xff0c;当超过变量的作用域后&#xff0c;java会自动释放掉为该变量所分配的JVM内存空间&#xff1b;而在堆中分配的JVM内存由java虚拟机的自动垃圾回收器来管理。…

python打开浏览器后带cookie_Python爬虫使用浏览器的cookies:browsercookie

很多用Python的人可能都写过网络爬虫&#xff0c;自动化获取网络数据确实是一件令人愉悦的事情&#xff0c;而Python很好的帮助我们达到这种愉悦。然而&#xff0c;爬虫经常要碰到各种登录、验证的阻挠&#xff0c;让人灰心丧气(网站&#xff1a;天天碰到各种各样的爬虫抓我们网…

VS插件开发

参考资料: VS插件开发 - 个性化VS IDE编辑器 自己动手编写一个VS插件&#xff08;一&#xff09; VS Addin插件基本开发入门 VS Addin插件配置、部署 转载于:https://www.cnblogs.com/wangwangfei/p/5830081.html

使用AspectJ,Javassist和Java Proxy进行代码注入的实用介绍

静态地或在运行时将代码片段注入已编译的类和方法中的功能可能会很有帮助。 这尤其适用于在没有源代码的第三方库中或在无法使用调试器或探查器的环境中对问题进行故障排除。 代码注入对于处理涉及整个应用程序的问题&#xff08;例如性能监视&#xff09;也很有用。 以这种方式…

Java中的变量

java类的成员变量有两种&#xff1a;一种是被static关键字修饰的变量&#xff0c;叫类变量或者静态变量&#xff1b;另一种没有static修饰&#xff0c;为实例变量。 在语法定义上的区别&#xff1a;静态变量前要加static关键字&#xff0c;而实例变量前则不加。 在程序运行时的…

无限漫游

一、FAT AP架构下&#xff0c;AP设备不做认证时&#xff1a; (1) AP1&#xff0c;AP2正常工作&#xff0c;发送Beacon帧&#xff0c;向STA通告支持的无线服务&#xff1b; (2) STA搜索到AP1的信号&#xff0c;向AP1发Probe Request,请求获取AP1所提供的无线服务&#xff1b;AP…

uni-app内置地图轨迹_MIUI11 新增亲情守护,支持安全围栏、运动轨迹功能

点击右上角关注我们&#xff0c;每天给您带来最新最潮的科技资讯&#xff0c;让您足不出户也知道科技圈大事&#xff01;日前&#xff0c;小米 MIUI 体验总负责人 MIUI小凡 在微博上为大家预告了 MIUI11 的新特性「亲情守护」&#xff0c;并表示「在亲情守护中&#xff0c;我们…

:before与:after伪类的应用

1.小三角样式 .tip{ position:relative; display:inline-block; width:100px; margin:100px; padding:30px 20px; color:#fff; border:1px solid #666; border-radius:5px; background-color:rgba(0,153,51,1);}.tip:before{ content:; posit…

小心重载API方法

重载方法是API设计中的重要概念&#xff0c;尤其是当您的API是流利的API或DSL&#xff08; 特定于域的语言 &#xff09;时。 对于jOOQ就是这种情况&#xff0c;在这种情况下&#xff0c;您经常想使用与完全相同的方法名称来与库进行各种交互。 示例&#xff1a;jOOQ条件 pac…

phpcms 下载模型列表页直接点击下载

下载模型设置本地下载 列表页模板直接调用 <article class"prjDown"><p class"prjDownTitle">方案下载</p><nav class"prjDownNav"><ul>{pc:content action"lists" catid"$catid" num"3…

为什么Java中类方法不能访问实例方法

我们已经知道类体中的方法分为实例方法和类方法两种&#xff0c;用static修饰的是类方法。二者有什么区别呢&#xff1f;当一个类创建了一个对象后&#xff0c;这个对象就可以调用该类的方法。 当类的字节码文件被加载到内存时&#xff0c;类的实例方法不会被分配入口地址&…

python展开 c函数中的宏预处理_C中的预处理宏

C中的预处理宏宏定义就属于预处理命令的一种。那么&#xff0c;什么是宏呢&#xff1f;宏&#xff1a;c语言标准允许在程序中用一个标识符来表示一个字符串。标识符就是宏名。宏替换&#xff1a;宏替换就是宏定义。在编译预处理中&#xff0c;将程序中所有的宏名用相应的字符串…

(转) 中断处理程序中断服务例程

关于中断处理程序和中断服务例程ISR的区别及联系&#xff0c;之前一直搞混&#xff0c;今天抽时间将两者关系弄弄清楚。ok,下面进入主题。首先中断处理程序(Interrupt Handler)和中断服务例程ISR(Inerrupt Service Routine)是两个不同的概念.简单来说就是&#xff0c;一条中断线…

使用SQL:2003 MERGE语句的奥术魔术

时不时地&#xff0c;由于以下任何原因&#xff0c;我们不得不将INSERT与UPDATE区分开来感到尴尬&#xff1a; 我们必须至少发表两个声明 我们必须考虑性能 我们必须考虑比赛条件 我们必须在[UPDATE; 如果UPDATE_COUNT 0 THEN INSERT]和[INSERT; 如果例外然后更新] 我们必…

Swing 学习小记

初学Swing一路问题&#xff0c;一路学习 问题一&#xff1a;JPanel中动态组件添加&#xff0c;刷新问题&#xff1f; 错误一&#xff1a;使用repaint()方法&#xff0c;以为可以刷新&#xff0c;可行不通。 错误继续发生&#xff1a;还是使用repaint()方法&#xff0c;与之前不…

leetcode Spiral Matrix

题目连接 https://leetcode.com/problems/spiral-matrix/ Spiral Matrix Description Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral order. For example, Given the following matrix: [   [ 1, 2, 3 ],   [ 4, 5…

python学生类出不来中文_Python 这类看起来学习门槛低的语言,是否真的适合入门编程学习?...

Python(计算机程序设计语言)Python是一种跨平台的计算机程序设计语言。 是一个高层次的结合了解释性、编译性、互动性和面向对象的脚本语言。最初被设计用于编写自动化脚本(shell)&#xff0c;随着版本的不断更新和语言新功能的添加&#xff0c;越多被用于独立的、大型项目的开…

克隆可序列化和不可序列化的Java对象

开发人员经常依靠3d方库来避免重新发明轮子&#xff0c;尤其是在Java世界中&#xff0c;Apache和Spring这样的项目如此盛行。 在处理这些框架时&#xff0c;我们通常很少或根本无法控制其类的行为。 这有时会导致问题。 例如&#xff0c;如果您想深度克隆不提供合适克隆方法的对…