Description

​ SnukeSnuke从他的母亲那里得到了生日礼物——一个网格。网格有HH行WW列。每个单元格都是黑色或白色。所有黑色单元格都是四联通的,也就是说,只做水平或垂直移动且只经过黑色单元格即可从任何黑色单元格移动到任何其他黑色单元格。
第ii行第jj列的单元格的颜色由字符si,jsi,j表示。如果si,jsi,j是 #,该单元格为黑色;如果si,jsi,j是 .,该单元格为白色。至少一个单元格是黑色的。
我们定义「分形」如下:00级分形是一个 1×11×1的黑色单元格.kk级分形由HH行WW列较小一级的分形按照 SnukeSnuke 的网格的样式拼成:与SnukeSnuke 网格中的黑色单元格对应的位置是一个kk级分形;与SnukeSnuke 网格中的白色单元格对应的位置是一个单元格全部为白色,尺寸与kk级分形相同的网格。
您将得到 SnukeSnuke 的网格的描述和整数 KK。请求出KK级分形中黑色单元格组成的连通分量数,模109+7109+7。

Input

​ 第一行三个整数H,W,K如题目描述

​ 接下来H行,每行W个字符

Output

​ 输出KK级分形中黑色单元格组成的连通分量数,模109+7109+7。

Sample Input

3 3 3
.#.
###
#.#

Sample Output

20

HINT

本题采用subtask。

真的抱歉部分分一拖再拖……

  • 存在5%5%的数据满足黑色方块与边界不相连。
  • 存在10%10%的数据满足KK级分形的边长≤2000≤2000。
  • 存在50%50%的数据满足黑色方块与四边界相连。

对于所有数据:

  • 1≤H,W≤10001≤H,W≤1000
  • 0≤K≤10180≤K≤1018
  • 每个 si,jsi,j是 # 或 .
  • 网格中所有黑色单元格四联通
  • 网格中至少有一个黑色单元格
.............#.............
............###............
............#.#............
..........#..#..#..........
.........#########.........
.........#.##.##.#.........
..........#.....#..........
.........###...###.........
.........#.#...#.#.........
....#........#........#....
...###......###......###...
...#.#......#.#......#.#...
.#..#..#..#..#..#..#..#..#.
###########################
#.##.##.##.##.##.##.##.##.#
.#.....#..#.....#..#.....#.
###...######...######...###
#.#...#.##.#...#.##.#...#.#
....#.................#....
...###...............###...
...#.#...............#.#...
.#..#..#...........#..#..#.
#########.........#########
#.##.##.#.........#.##.##.#
.#.....#...........#.....#.
###...###.........###...###
#.#...#.#.........#.#...#.#

这个是第一个样例的样例解释

第二个样例:

3 3 3
###
#.#
###OUTPUT:1

第三个样例:

11 15 1000000000000000000
.....#.........
....###........
....####.......
...######......
...#######.....
..##.###.##....
..##########...
.###.....####..
.####...######.
###############
#.##..##..##..#OUTPUT:301811921

Sol

%%%DTZ

其实这题不是很难想,但是看起来太神了觉得不是很可做所以当时就索性放弃了QWQ

Code

#include <bits/stdc++.h>
using namespace std;
#define P 1000000007
int n,m,x,y,z;char s[1005][1005],t[1005][1005];long long k;
struct M
{long long m[5][5];M(){memset(m,0,sizeof(m));}M operator*(const M &b)const{M c;for(int i=1,j,k;i<=2;i++) for(j=1;j<=2;j++) for(k=1;k<=2;k++) (c.m[i][j]+=m[i][k]*b.m[k][j])%=P;return c;}M operator^(long long x)const{M a(*this),ans;for(int i=1;i<=2;i++)ans.m[i][i]=1;for(;x;x>>=1,a=a*a) if(x&1)ans=ans*a;return ans;}
}ans;
int ksm(int x,long long y){int ans=1;for(;y;y>>=1,x=1ll*x*x%P) if(y&1) ans=1ll*ans*x%P;return ans;}
bool chk(){for(int i=1;i<=n;i++) if(s[i][1]=='#'&&s[i][m]=='#') return 1;return 0;}
void turn90(){for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) t[m-j+1][i]=s[i][j];swap(n,m);memcpy(s,t,sizeof(s));}
int main()
{scanf("%d%d%lld",&n,&m,&k);for(int i=1,j;i<=n;i++) for(scanf("%s",s[i]+1),j=1;j<=m;j++) x+=s[i][j]=='#';bool a=chk(),b=(turn90(),chk());turn90();if(a&&b) return printf("1"),0;else if(!a&&!b) return printf("%d",ksm(x,k-1)),0;else if(b) turn90();for(int i=1;i<=n;i++) z+=s[i][1]=='#'&&s[i][m]=='#';for(int i=1;i<=n;i++) for(int j=1;j<m;j++) y+=s[i][j]=='#'&&s[i][j+1]=='#';ans.m[1][1]=x,ans.m[1][2]=y,ans.m[2][2]=z;ans=ans^(k-1);printf("%lld",(ans.m[1][1]-ans.m[1][2]+P)%P);
}

转载于:https://www.cnblogs.com/CK6100LGEV2/p/9489691.html

[AGC003F] Fraction of Fractal 矩阵快速幂相关推荐

  1. 矩阵快速幂+构造方法

    与快速幂一样,可以将递推式通过二进制的方式来进行优化,这个学了快速幂就是十分容易理解 大概的板子如下: struct mat///自己定义大小的矩阵 {ll m[11][11]; }; mat mul ...

  2. 【做题】SRM701 Div1 Hard - FibonacciStringSum——数学和式&矩阵快速幂

    原文链接 https://www.cnblogs.com/cly-none/p/SRM701Div1C.html 题意:定义"Fibonacci string"为没有连续1的01串 ...

  3. 快速幂 + 矩阵快速幂

    快速幂 1 #include<iostream> 2 #include<algorithm> 3 #include<cstring> 4 #define LL lo ...

  4. HDU4549(矩阵快速幂+快速幂)

    f(n)=a^f(n-1) + b^f(n-2):计算矩阵部分用矩阵快速幂:计算a的幂次和b的幂次用快速幂. #include<iostream> #include<algorith ...

  5. [HNOI2008]GT考试[矩阵快速幂+kmp优化的dp]

    解题思路:假如说我们用f[i]表示长度为i的串能组合成无不吉利数字的组合的个数的话我们无法找到f[i]和f[i+1]的关系,就是我们下一位填某个数字会不会出现不吉利串,这就和你前面的串末尾于不吉利串重 ...

  6. I-Matrix Power Series POJ - 3233 矩阵快速幂+分治

    I-Matrix Power Series POJ - 3233 矩阵快速幂+分治 Problem Description Given a n × n matrix A and a positive ...

  7. H - Fibonacci POJ - 3070 (矩阵快速幂)

    H - Fibonacci POJ - 3070 (矩阵快速幂) Description In the Fibonacci integer sequence, F0 = 0, F1 = 1, and ...

  8. HDU 6185 Covering 矩阵快速幂 递推

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=6185 题目描述: 一个4*n的矩形, 你用1*2的矩形覆盖有多少种方案, n <= 1e18 ...

  9. bzoj 1409 Password 矩阵快速幂+欧拉函数

    可以发现,该数组的mi就是斐波那契数列 所以要矩阵快速幂搞出第n位 但是斐波那契数列上涨的很快,这就需要欧拉定理了 p^phi(q)%q=1(gcd(p,q)==1) p是素数,所以可以用 然后需要5 ...

  10. POJ 2778 DNA Sequence [AC自动机 + 矩阵快速幂]

    http://poj.org/problem?id=2778 题意:给一些只由ACGT组成的模式串,问有多少种长度为n且不含有给出的模式串的DNA序列. 自动机的状态转换可以看成一个有向图(有重边的) ...

最新文章

  1. 转:Silverlight样式写法
  2. Category简介 (上篇)
  3. 单核工作法12:现在专注一件事(下)
  4. [转]Android输入法框的梳理
  5. 逻辑地址、线性地址、物理地址和虚拟地址初步认识
  6. 利用Android中的三大主件来实现一个码表
  7. 计蒜客 逃生+动态规划
  8. hibernate oracle查询最大值_Java大数据:Mybatis和Hibernate对比分析
  9. 2012r2配置java_JDK+Tomcat 服务器配置+腾讯云Win2012 R2 配置安装
  10. Java面向对象的思想
  11. 一个小型的中文文本分类系统(项目链接文末)——《ML算法原理和实践》学习笔记
  12. H.266/VVC代码学习:xCheckRDCostMerge2Nx2N函数
  13. 开源微服务框架 汇总
  14. 缠中说禅形态挖掘之九笔形态
  15. 提示msvcr71.dll丢失处理办法
  16. leetcode 14天刷题计划-数据结构入门(共计33题)
  17. Codewars-Java编程刷题学习4-Jaden Casing Strings
  18. python chunk模块
  19. 5种让你入门免费学习编程的方法
  20. 数据字典模板_C++ 模板元编程:一种屠龙之技

热门文章

  1. 请描述计算机软件分类,2014年计算机一级考试MsOffice模拟题
  2. linux安装python的拓展包,linux 安装python拓展包pexpect
  3. php接口ip验证,php – IP地址验证帮助
  4. java的架构有哪些,java架构有哪些?
  5. focal loss dice loss源码_扒源码:sharding loss in Pytorch
  6. AIX学习之NMON工具详解
  7. iOS 中 常用的第三方库
  8. 物联网发展 制定技术标准才能更好监管
  9. 使用docker compose 测试集群网络连接性
  10. window下连接ubuntu mysql的问题