//==========================

蒟蒻Macaulish:http://www.cnblogs.com/Macaulish/  转载要声明!

//==========================

事情是这样的。太久没切矩阵找了两道题爽一爽。然后泰林大神就满脸堆笑地说大神来坐坐这道题吧!

然后我就来看这题。然后觉得这题没多难啊,直接用类似最短路的方法,然后只要把图存成矩阵就可以矩阵搞一搞啊。

然后愉快的码好,交上去,wa

傻了。对着代码看了很久还是不行。决定写对拍。然后泰林大神说黄学长有写,这样好啊,就直接拿黄学长的来对拍。

小数据似乎没有问题。大数据似乎也没有问题啊。然后拍了很久才发现自己数据造的不行,答案都小于maxlongint(教训1)

然后就造了答案会超maxlongint的数据,结果果然错了!

然后就发现没有可能错啊,该int64的地方都有啊。

找了很久才发现,问题在于1<<i上,然后我就愉快的1<<in64(i),这下没错了吧,显然还是错&……大神们围过来说,应该写成这样int64(1)<<i(教训2)。擦我当时有脑子么?

然后一交tle……

然后就走上了调常数的不归路。

然后不会调常数发现也是徒劳。期间试着改了几次都没有用。

然后勾搭到了初三神牛dwjshift !!!!!

大神和我说了很久,提出了各种改进方法,并且在所有方法还是t了之后还友情提供了代码

然后还是t了。然后就跑去睡觉了。

晚上看着到了12点,是时候调常数了(我是不是很好人,晚上没人提交这样卡测评也不会掉rp)

然后打开程序,然后发现下午脑袋吃屎了……倍增找到第一个>=m后我竟然只是跳出了找的那个for(教训3)!然后程序继续跑倍增……

然后就用了大神说的几个方法

改变矩乘的for循环

运算符重载传数组可能慢在程序里面写三个for

然后可以等到这个数组都处理完再去处理那些≥m的值变为m

矩阵初始是最后一个倍增矩阵中没有超过m的,记录一下。

然后提交

然后速度好快啊(虽然还是被c++碾压一脸)

然后终于过了这道常数题(p也是可以调常数的(雾))!)

恩,血泪史

type
arr=array[..,..]of int64; var
map:array[..]of arr;
f:array[..]of arr;
pow:array[..]of int64;
t,n,i:longint;
m:int64; procedure into;
var
i,j,k,trsum,now,tot,ii,jj,kk:longint;
big,ans:int64;
flag:boolean;
begin
readln(n,m);
for i:= to n do
for j:= to n do
read(map[,i,j]);
trsum:=trunc(ln(m)/ln())+;
tot:=trsum;
for i:= to trsum do begin
for ii:= to n do begin
for jj:= to n do map[i,ii,jj]:=;
for kk:= to n do
if map[i-,ii,kk]<> then
for jj:= to n do
if (map[i-,kk,jj]<>) and (map[i,ii,jj]<map[i-,ii,kk]+map[i-,kk,jj]) then
map[i,ii,jj]:=map[i-,ii,kk]+map[i-,kk,jj];
end;
//map[i]:=map[i-]*map[i-];
flag:=true;
for j:= to n do
if map[i,,j]>=m then begin
tot:=i;
flag:=false;
break;
end;
if not flag then break;
for ii:= to n do
for jj:= to n do
if map[i,jj,kk]>m then map[i,jj,kk]:=m;
end;
now:=;
f[now]:=map[tot-];
ans:=pow[tot-];
for i:=tot- downto do begin for ii:= to n do begin
for jj:= to n do f[-now,ii,jj]:=;
for kk:= to n do
if f[now,ii,kk]<> then
for jj:= to n do
if (map[i,kk,jj]<>) and (f[-now,ii,jj]<f[now,ii,kk]+map[i,kk,jj]) then
f[-now,ii,jj]:=f[now,ii,kk]+map[i,kk,jj];
end;
big:=;
for j:= to n do
if big<f[-now,,j] then big:=f[-now,,j];
if big<m then begin
ans:=ans+pow[i];
now:=-now;
for ii:= to n do
for jj:= to n do
if f[now,ii,jj]>m then f[now,ii,jj]:=m;
end;
end;
writeln(ans+);
end; begin
readln(t);
pow[]:=;
for i:= to do
pow[i]:=pow[i-]<<;
while t> do begin
into;
dec(t);
end;
end.

bzoj2165: 大楼 (矩阵快速幂)的更多相关文章

  1. 矩阵快速幂 HDU 4565 So Easy!(简单?才怪!)

    题目链接 题意: 思路: 直接拿别人的图,自己写太麻烦了~ 然后就可以用矩阵快速幂套模板求递推式啦~ 另外: 这题想不到或者不会矩阵快速幂,根本没法做,还是2013年长沙邀请赛水题,也是2008年Go ...

  2. 51nod 算法马拉松18 B 非010串 矩阵快速幂

    非010串 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 如果一个01字符串满足不存在010这样的子串,那么称它为非010串. 求长度为n的非010串的个数.(对1e9+7取模) ...

  3. 51nod 1113 矩阵快速幂

    题目链接:51nod 1113 矩阵快速幂 模板题,学习下. #include<cstdio> #include<cmath> #include<cstring> ...

  4. 【66测试20161115】【树】【DP_LIS】【SPFA】【同余最短路】【递推】【矩阵快速幂】

    还有3天,今天考试又崩了.状态还没有调整过来... 第一题:小L的二叉树 勤奋又善于思考的小L接触了信息学竞赛,开始的学习十分顺利.但是,小L对数据结构的掌握实在十分渣渣.所以,小L当时卡在了二叉树. ...

  5. HDU5950(矩阵快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5950 题意:f(n) = f(n-1) + 2*f(n-2) + n^4,f(1) = a , f(2 ...

  6. 51nod 1126 矩阵快速幂 水

    有一个序列是这样定义的:f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * f(n - 2)) mod 7. 给出A,B和N,求f(n)的值. Input 输 ...

  7. hdu2604(递推,矩阵快速幂)

    题目链接:hdu2604 这题重要的递推公式,找到公式就很easy了(这道题和hdu1757(题解)类似,只是这道题需要自己推公式) 可以直接找规律,推出递推公式,也有另一种找递推公式的方法:(PS: ...

  8. 矩阵乘法&矩阵快速幂&矩阵快速幂解决线性递推式

    矩阵乘法,顾名思义矩阵与矩阵相乘, 两矩阵可相乘的前提:第一个矩阵的行与第二个矩阵的列相等 相乘原则: a b     *     A B   =   a*A+b*C  a*c+b*D c d     ...

  9. hdu4965 Fast Matrix Calculation (矩阵快速幂 结合律

    http://acm.hdu.edu.cn/showproblem.php?pid=4965 2014 Multi-University Training Contest 9 1006 Fast Ma ...

  10. 2013长沙邀请赛A So Easy!(矩阵快速幂,共轭)

    So Easy! Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

随机推荐

  1. Drupal 判断匿名用户必须先登录的解决方法

    要实现如果是匿名用户点击checkout链接,要求先登录 方案一.通过添加Rules规则实现 EVENT:After adding a product to the cart Conditions : ...

  2. vim中project多标签和多窗口的使用

    1.打开多个窗口 打开多个窗口的命令以下几个: 横向切割窗口 :new+窗口名(保存后就是文件名) :split+窗口名,也可以简写为:sp+窗口名 纵向切割窗口名 :vsplit+窗口名,也可以简写 ...

  3. C#中创建二维数组,使用[][]和[,]的区别

    C#中,我们在创建二维数组的时候,一般使用arr[][]的形式,例如 int[][] aInt = new int[2][]; 但声明二维数组还有一种方法,是使用arr[,]的形式.两者有什么区别呢? ...

  4. iOS - Foundation相关

    1.NSString         A.创建的方式:            stringWithFormat:格式化字符串  ,创建字符串对象在堆区域            @"jack& ...

  5. APP九宫格滑动解锁的处理

    写手机自动化测试脚本关于APP九宫格滑动解锁方面采用了appium API 之 TouchAction 操作. 先是用uiautomatorviewer.bat查询APP元素坐标: 手工计算九宫格每个 ...

  6. CodeForces - 1059D(二分+误差)

    链接:CodeForces - 1059D 题意:给出笛卡尔坐标系上 n 个点,求与 x 轴相切且覆盖了所有给出点的圆的最小半径. 题解:二分半径即可.判断:假设当前二分到的半径是 R ,因为要和 x ...

  7. [SHELL]shell中的数学运算

    一,expr  太麻烦,看的脑壳疼 二,使用方括号 !!!! bash shell用这种方法只支持整数运算,z shell倒是支持浮点型运算 var_1= var_2= var_3= my_var_1 ...

  8. C++ 学习笔记之——字符串和字符串流

    1. 字符数组 字符数组,也就是存放字符类型数据的数组,只不过字符数组的结尾必须是 '\0'.C++ 已经提供了一些字符串处理函数,这些函数被封装在头文件 和 <string.h> 中. ...

  9. 基于深度学习的中文语音识别系统框架(pluse)

    目录 声学模型 GRU-CTC DFCNN DFSMN 语言模型 n-gram CBHG 数据集 本文搭建一个完整的中文语音识别系统,包括声学模型和语言模型,能够将输入的音频信号识别为汉字. 声学模型 ...

  10. jquery取radio单选按钮

    // var strMess = '<%=Exchange() %>';//            if (strMess == "兑换成功") {//         ...