Vijos 1067守望者的烦恼
背景
守望者-warden,长期在暗夜精灵的的首都艾萨琳内担任视察监狱的任务,监狱是成长条行的,守望者warden拥有一个技能名叫“闪烁”,这个技能可以把她传送到后面的监狱内查看,她比较懒,一般不查看完所有的监狱,只是从入口进入,然后再从出口出来就算完成任务了。
描述
头脑并不发达的warden最近在思考一个问题,她的闪烁技能是可以升级的,k级的闪烁技能最多可以向前移动k个监狱,一共有n个监狱要视察,她从入口进去,一路上有n个监狱,而且不会往回走,当然她并不用每个监狱都视察,但是她最后一定要到第n个监狱里去,因为监狱的出口在那里,但是她并不一定要到第1个监狱。
守望者warden现在想知道,她在拥有k级闪烁技能时视察n个监狱一共有多少种方案?
格式
输入格式
第一行是闪烁技能的等级k(1<=k<=10)
第二行是监狱的个数n(1<=n<=2^31-1)
输出格式
由于方案个数会很多,所以输出它 mod 7777777后的结果就行了
样例1
样例输入1
2
4
样例输出1
5
限制
各个测试点1s
提示
把监狱编号1 2 3 4,闪烁技能为2级,
一共有5种方案
→1→2→3→4
→2→3→4
→2→4
→1→3→4
→1→2→4
小提示:建议用int64,否则可能会溢出
题解:
设dp[i],表示跳到i节点的方案数,显然dp[i]=sigam dp[j](i>j>=max(i-k,0))意思就是说可以从这些节点跳过来,所以这其实只是一个递推而已,所以我们可以开两个k*k的矩阵,用矩阵快速幂来解决,所以初始矩阵就是把dp[0]填到a[1][k]的位置,目标矩阵的最上面一行都是dp[i~i-k],每次*一次i就加1,(当然快速幂优化),转移矩阵就可以通过目标矩阵写出来了。
代码:
#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<cstring>
#include<algorithm>
#define ll long long
#define mod 7777777
using namespace std;
struct jvzhen{
ll s[][];
}a,b;
int n,k; jvzhen jvcheng(jvzhen x,jvzhen y){
jvzhen c;
memset(c.s,,sizeof(c.s));
for(int i=;i<=k;i++)
for(int j=;j<=k;j++)
for(int kk=;kk<=k;kk++)
c.s[i][j]+=x.s[i][kk]*y.s[kk][j],c.s[i][j]%=mod;
return c;
} int main(){
scanf("%d%d",&k,&n);
memset(a.s,,sizeof(a.s));
memset(b.s,,sizeof(b.s));
a.s[][k]=;
for(int i=;i<k;i++) b.s[i+][i]=;
for(int i=;i<=k;i++) b.s[i][k]=;
while(n){
if(n&) a=jvcheng(a,b);
b=jvcheng(b,b);
n>>=;
}
printf("%lld",a.s[][k]);
}
Vijos 1067守望者的烦恼的更多相关文章
- C++矩阵加速经典题目:Warcraft III 守望者的烦恼 [vijos 1067]
		
Warcraft III 守望者的烦恼 背景 守望者-warden,长期在暗夜精灵的的首都艾萨琳内担任视察监狱的任务,监狱是成长条行的,守望者warden拥有一个技能名叫"闪烁", ...
 - vijosP1067Warcraft III 守望者的烦恼
		
vijosP1067Warcraft III 守望者的烦恼 链接:https://vijos.org/p/1067 [思路] 矩阵乘法. 可以得出递推式: f[i]=sum{ f[n-1], ...
 - P1067Warcraft III 守望者的烦恼(十大矩阵问题之七求递推式)
		
https://vijos.org/p/1067 守望者-warden,长期在暗夜精灵的的首都艾萨琳内担任视察监狱的任务,监狱是成长条行的,守望者warden拥有一个技能名叫“闪烁”,这个技能可以把她 ...
 - [矩阵十题第七题]vijos 1067 Warcraft III 守望者的烦恼 -矩阵快速幂
		
背景 守望者-warden,长期在暗夜精灵的的首都艾萨琳内担任视察监狱的任务,监狱是成长条行的,守望者warden拥有一个技能名叫“闪烁”,这个技能可以把她传送到后面的监狱内查看,她比较懒,一般不查看 ...
 - (VIJOS) VOJ 1067 Warcraft III 守望者的烦恼 矩阵快速幂
		
https://vijos.org/p/1067 就..挺普通的一道题..自己学一下怎么推式子就可以...细节不多但是我还是日常爆细节..比如说循环写成从负数开始... 只求ac不求美观的丑陋 ...
 - vijos 1067 Warcraft III 守望者的烦恼    矩阵
		
题目链接 我们可以很容易的推出dp的式子, dp[i] = sigma(j : 1 to k) dp[i-j]. 但是n太大了, 没有办法直接算, 所以我们构造一个矩阵, 然后快速幂就好了. 就像这样 ...
 - Vijos P1067Warcraft III 守望者的烦恼
		
题目 背景 守望者-warden,长期在暗夜精灵的的首都艾萨琳内担任视察监狱的任务,监狱是成长条行的,守望者warden拥有一个技能名叫“闪烁”,这个技能可以把她传送到后面的监狱内查看,她比较懒,一般 ...
 - VOJ 1067 Warcraft III 守望者的烦恼 (矩阵高速功率+dp)
		
主题链接 明显的 dp[n] = dp[n-k] + dp[n-k+1] + ... +dp[n-1]; 然后要用矩阵来优化后面的状态转移. 也就是矩阵 0 1 0 0 a b 0 0 ...
 - vijos Warcraft III 守望者的烦恼
		
题解 转移方程好写吧 一个一维递推式 然后我们可以构造矩阵优化 嗯,最近学一下递推优化 代码 #include<cstdio> #include<cstring> #inclu ...
 
随机推荐
- 【入门】广电行业DNS、DHCP解决方案详解(三)——DNS部署架构及案
			
[入门]广电行业DNS.DHCP解决方案详解(三)——DNS部署架构及案 DNS系统部署架构 宽带业务DNS架构 互动业务DNS架构 案例介绍 案例一 案例二 本篇我们将先介绍DNS系统部署架构体系, ...
 - Https、OpenSSL自建CA证书及签发证书、nginx单向认证、双向认证及使用Java访问
			
0.环境 本文的相关源码位于 https://github.com/dreamingodd/CA-generation-demo 必须安装nginx,必须安装openssl,(用apt-get upd ...
 - Winform中设置Dialog的显示位置居中
			
场景 点击按钮使窗体以Dialog的方式显示,即弹窗. //声明窗体对象 ChartOption chartOption = new ChartOption(); //显示Dialog chartOp ...
 - python+selenium调用chrome打开网址获取内容
			
目录 1,安装selenium和配置chromedriver 2,调用chromedriver打开网页获取网页内容 3,模拟登陆百度云 附录(webdriver版本兼容列表) 通过selenium库, ...
 - CSS——设置背景
			
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
 - Linux 笔记 - 第六章 Linux 磁盘管理
			
博客地址:http://www.moonxy.com 一.前言 1.1 硬盘 硬盘一般分为 IDE 硬盘.SCSI 硬盘和 SATA 硬盘.在 Linux 中,IDE 接口的设备被称为 hd,SCSI ...
 - chrome,firefox浏览器字体发虚解决办法
			
打开微软自家的edge浏览器,字体就没有问题,刚开始以为是浏览器的问题,调整半天也没有效果,后来怀疑是Windows系统的问题,于是尝试调整字体,成功解决! 解决方案: 进入个性化->字体-&g ...
 - [VB.NET Tips]为VB.NET正名
			
前言 我于2005年毕业,正值全国上上下下如火如荼的开展企业信息化的时代,正是大规模软件开发的年代. 那时.NET 已经发布了2.0,但是仍是VB6,Delphi,PowerBuilder的天下,是E ...
 - 理解JavaScript中的this关键字
			
JavaScript中this关键字理解 在爬虫的过程中遇到了前端的js代码,对于this关键字理解的不是很清楚,所以写下这篇笔记,不足之处,希望得以改之. this的指向在函数定义的时候无法确定,只 ...
 - dom4j.jar下载
			
下载地址: 链接:https://pan.baidu.com/s/16GCgCpaF7dc33pMbK2sTLg 密码:z444