vijos上的题解:

1.因为每个格子不是被覆盖就是没被覆盖,状态只有0 1两种,m<=5,所以可以将每一列的状态压缩,看作一个二进制数.
2.矩阵G表示从I状态到J状态的路径条数,自乘N次为长度为N的路径条数。
3.矩阵乘法可以用快速幂优化,时间复杂度为O(logN*(2^M)^3)可以接受
4.用I表示前一个状态,J表示这个状态,则I可以到达J的条件是:(K = 2^M - 1 )
I OR J = K 且 I AND J = AG[W]
I状态未能填满的格子均由横向1*2的骨牌填充,此时J状态相应的位置也填充了骨牌,因此要满足I OR J = K,即I和J状态此时互补。
又在J状态下可以继续填充竖向2*1的骨牌,这些骨牌的位置可由I AND J得到,所以I AND J必须满足 I AND J = AG[W]
AG[W]为在宽度为M是竖向填充2*1的骨牌的所有方案。
ag:Array[0..7]of longint = (0,3,6,12,15,24,27,30);
把里面的数字转换成2进制就知道这个数组的干吗用的了。
5.再次感谢matrix67大牛,膜拜ing...

还有需要弄清的问题是把每个数字转换为2进制后,1表示此位置被覆盖,0表示未被覆盖。但为什么需要 i  or  j=1<<m -1 并且 i and j=这些奇怪的数字呢?

其实我们可以这样考虑,我们现在所在的这一行,假设是n行,要过度到n+1行,所以这一行上面的0必须被填上,这样n+1行的同一个位置必定有1,

这是横着铺了一个骨牌的结果,所以i or j=1<<m-1

那为什么要有i and j=那些呢?

我们思考,当把第n行铺满之后,在n+1行上竖着铺放骨牌还可以得到不同的方案数,而这时能铺的只有n行的1所在的位置,而且必须是若干个两个连着的1。

而 i and j 的1所在位置就是新铺的竖着的骨牌,它必须等于某些特定的值,而不能等于其它的值 比如 01010 这是显然不可能,他是怎么铺上的呢?

事实上,我们把AG数组的所有转化为二进制即:

00000,00011,00110,01100,01111,11000,11011,11110

这为我们提供了所有可行的i and j 的值

Q.E.D

代码:

  1. const ag:array[..]of longint=(,,,,,,,);
  2. type matrix=array[..,..] of longint;
  3. var a,b:matrix;
  4. i,j,k,m,n,p,ans:longint;
  5. function mo(x:longint):longint;
  6. begin
  7. mo:=x mod p;
  8. end;
  9. procedure init;
  10. begin
  11. readln(n,m,p);
  12. fillchar(a,sizeof(a),);
  13. fillchar(b,sizeof(b),);
  14. m:=(<<m)-;
  15. for i:= to m do
  16. for j:= to m do
  17. if i or j=m then
  18. for k:= to do
  19. if i and j=ag[k] then a[i,j]:=;
  20. for i:= to m do b[i,i]:=;
  21. end;
  22. procedure mul(var x,y,z:matrix);
  23. var t:matrix;
  24. i,j,k:longint;
  25. begin
  26. fillchar(t,sizeof(t),);
  27. for i:= to m do
  28. for j:= to m do
  29. for k:= to m do
  30. t[i,j]:=mo(t[i,j]+x[i,k]*y[k,j]);
  31. z:=t;
  32. end;
  33. procedure ksm(cs:longint);
  34. begin
  35. while cs<> do
  36. begin
  37. if cs and = then mul(a,b,b);
  38. cs:=cs>>;
  39. mul(a,a,a);
  40. end;
  41. end;
  42. procedure main;
  43. begin
  44. ksm(n);
  45. writeln(b[m,m]);
  46. end;
  47. begin
  48. init;
  49. main;
  50. end.

还有一个小问题,这里A数组自乘了n次,而且最后直接输出了b[m,m],这是为什么呢?

我们可以假想初始状态为0行铺满了格子,每乘一次都得到了下一行的结果,所以n此后得到了第n行的结果,A[n,n]表示的就是从第0行铺满到第n行铺满的方案数。

vijos1194 Domino的更多相关文章

  1. BPM Domino集成解决方案

    一.需求分析 Lotus Notes/Domino是IBM的协同办公平台,在国内有广泛的用户. 但由于推出年头较早.采用文档数据库等特点, 导致其流程集成能力弱.统计分析难.不支持移动办公等问题,很多 ...

  2. 【转载】给那些想多学习,多进步的Domino初学者

    在这个社区里面,包括QQ技术群里面混了很久了.遇到了很多Domino初学者,也认识了很多致力于Domino这个技术领域的朋友,很开心.很久没有写长篇大论给大家了.我要把一些想法写出来,共大家参考.讨论 ...

  3. FineReport中Domino数据库连接方法

    1. 概述 Domino是文档型数据库而非关系型数据库,连接Domino可以使用JDBC方式或者ODBC方式,使用JDBC方式需要安装Lotus Domino Driver for JDBC并且此方法 ...

  4. IBM Domino 9 出现 Server Controller 未在主机上运行或未在端口2050监听 解决方案

    如果在网上搜索的方法,比如防火墙开端口还没有解决的话,那么我的解决方案可能会解决你的问题. 出现的场景: 我先装了Notes,Designer,后装Domino Server, 配置Domino服务器 ...

  5. CF 405B Domino Effect(想法题)

    题目链接: 传送门 Domino Effect time limit per test:1 second     memory limit per test:256 megabytes Descrip ...

  6. [ACM_图论] Domino Effect (POJ1135 Dijkstra算法 SSSP 单源最短路算法 中等 模板)

    Description Did you know that you can use domino bones for other things besides playing Dominoes? Ta ...

  7. 如何开发Domino中的WebService

    在domino中写webservice可以使用LotusScript,也可以使用java,由于LotusScript API提供的功能多数都是操作domino数据库中文档的,在web service中 ...

  8. 结合Domino打造全功能的Grid

    1.       需求说明: 在domino开发中我们经常会遇到表单上需要一个类似table的组件,你可以增删改等.比如我有一个张报核单据,上面需要详细列出每项金额的明细,我们先看完成后的效果: 上面 ...

  9. 关于Domino数据库的软删除

    在Domino的数据库属性的 “高级” 附签(选择文件->数据库->属性),选中“允许软删除”,这样我们就启用了软删除功能,当一个文档没有删除的时候我们可以使用NotesDatabase的 ...

随机推荐

  1. c#中sqlhelper类的编写(一)

    在.net平台的项目开发中,凡是用到数据库交互的,都有必要了解SqlHelper类的原理. 步骤一: 我就拿WPF项目开发作为例子.首先要新建一个App.config(应用程序配置文件).注意,在VS ...

  2. matlab之点运算基本思想及几何平移变换

    1.对数变换可以增强图像中较暗部分的细节,因为对数可以将较小的值放大,而较大的值缩小 2.伽马变换:y = (x + esp) ^ γ,x,y的取值范围是0到1,esp是补偿系数,γ为伽马系数.γ的不 ...

  3. liunx命令之whereis、which、find的区别和联系

    liunx命令之whereis.which.find的区别和联系

  4. ASP.NET中POST数据并跳转页面

    需求:先Post提交数据,然后跳转到目标页面 找了好久才发现这个神奇的类HttpHelper.原理很简单,利用html的from表单拼接,然后执行 使用方法: NameValueCollection ...

  5. 2016 系统设计第一期 (档案一)MVC 引用 js css

    @Styles.Render("~/Bootstrap/css/bootstrap-theme.css") @Scripts.Render("~/jQuery/jquer ...

  6. Jquery Highcharts 选项配置 说明文档

    Highcharts提供大量的选项配置参数,您可以轻松定制符合用户要求的图表,下面为Highcharts常用的最核心的参数选项配置. Chart:图表区选项 Chart图表区选项用于设置图表区相关属性 ...

  7. FormBorderStyle.None 时候最大化不遮盖任务栏

    this.FormBorderStyle = FormBorderStyle.None;             this.MaximumSize = new Size(Screen.PrimaryS ...

  8. c++ 链接

    header.h #ifndef HEADER_H #define HEADER_H unsigned long getFac(unsigned short num); ; #endif // HEA ...

  9. hibernate添加数据,默认字段为null的问题解决

    数据库中的一个字段默认为0,但是在用hibernate的添加之后,默认字段竟然不是0,为NULL. 查了一下.发现想要让默认字段生效.需要在*.hbm.xml添加一些参数,如下.(红色部分) dyna ...

  10. hdu 4577 X-Boxes 大数

    java水过…… 代码如下: import java.math.*; import java.util.*; public class Main { public static void main(S ...