牛客练习赛1 A - 矩阵
链接:https://www.nowcoder.com/acm/contest/2/A
来源:牛客网
题目描述
输入描述:
第一行两个整数n, m代表矩阵的长和宽;
接下来n行,每行m个字符(小写字母),表示矩阵;
输出描述:
输出一个整数表示满足条件的最大正方形的边长。
输入例子:
5 10
ljkfghdfas
isdfjksiye
pgljkijlgp
eyisdafdsi
lnpglkfkjl
输出例子:
3
-->
输入
5 10
ljkfghdfas
isdfjksiye
pgljkijlgp
eyisdafdsi
lnpglkfkjl
输出
3
备注:
对于30%的数据,n,m≤100;
对于100%的数据,n,m≤500;
题解
二分,字符串$hash$。
可以二分答案,然后验证,验证的时候$O(n^2)$效率可以得到每一个正方形的$hash$值,判断一下即可,注意$hash$冲突,用了两次$hash$才过。
#include<bits/stdc++.h>
using namespace std; long long base[2];
long long mod[2];
const int maxn = 500 + 10;
int n, m;
char s[maxn][maxn];
long long b[2][maxn * maxn];
long long sum[2][maxn][maxn];
long long h[2][maxn][maxn];
pair<long long, long long> pi[maxn * maxn]; void init() {
base[0] = 131LL;
base[1] = 313LL;
mod[0] = 1e9 + 7;
mod[1] = 1e9 + 7;
} int check(int x) {
for(int t = 0; t < 2; t ++) {
for(int i = 0; i < n; i ++) {
long long C = 0;
for(int j = 0; j < x; j ++) {
C = C * base[t] % mod[t];
C = (C + s[i][j]) % mod[t];
}
sum[t][i][0] = C;
for(int j = 1; j + x - 1 < m; j ++) {
long long A = sum[t][i][j - 1];
long long B = s[i][j - 1] * b[t][x - 1] % mod[t];
A = (A - B + mod[t]) % mod[t];
A = A * base[t] % mod[t];
A = (A + s[i][j + x - 1]) % mod[t];
sum[t][i][j] = A;
}
}
for(int j = 0; j < m; j ++) {
long long C = 0;
for(int i = 0; i < x; i ++) {
C = C * b[t][x] % mod[t];
C = (C + sum[t][i][j]) % mod[t];
}
h[t][0][j] = C;
}
for(int i = 1; i + x - 1 < n; i ++) {
for(int j = 0; j + x - 1 < m; j ++) {
long long A = h[t][i - 1][j];
long long B = sum[t][i - 1][j] * b[t][x * (x - 1)] % mod[t];
A = (A - B + mod[t]) % mod[t];
A = A * b[t][x] % mod[t];
A = (A + sum[t][i + x - 1][j]) % mod[t];
h[t][i][j] = A;
}
}
} int sz = 0;
for(int i = 0; i + x - 1 < n; i ++) {
for(int j = 0; j + x - 1 < m; j ++) {
pi[sz].first = h[0][i][j];
pi[sz].second = h[1][i][j];
sz ++;
}
}
sort(pi, pi + sz);
for(int i = 1; i < sz; i ++) {
if(pi[i] == pi[i - 1]) return 1;
} return 0;
} int main() {
init();
b[0][0] = 1LL;
b[1][0] = 1LL;
for(int i = 1; i <= 250000; i ++) {
b[0][i] = b[0][i - 1] * base[0] % mod[0];
b[1][i] = b[1][i - 1] * base[1] % mod[1];
}
scanf("%d%d", &n, &m);
for(int i = 0; i < n; i ++) {
scanf("%s", s[i]);
}
int L = 1, R = min(n, m), ans = 0;
while(L <= R) {
int mid = (L + R) / 2;
if(check(mid)) L = mid + 1, ans = mid;
else R = mid - 1;
}
printf("%d\n", ans);
return 0;
} /* 5 10
ljkfghdfas
isdfjksiye
pgljkijlgp
eyisdafdsi
lnpglkfkjl */
牛客练习赛1 A - 矩阵的更多相关文章
- 【并查集缩点+tarjan无向图求桥】Where are you @牛客练习赛32 D
		
目录 [并查集缩点+tarjan无向图求桥]Where are you @牛客练习赛32 D PROBLEM SOLUTION CODE [并查集缩点+tarjan无向图求桥]Where are yo ...
 - 牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 逻辑,博弈 B
		
牛客练习赛31 B 赞迪卡之声妮莎与奥札奇 https://ac.nowcoder.com/acm/contest/218/B 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 2621 ...
 - 牛客练习赛31 D 神器大师泰兹瑞与威穆 STL,模拟 A
		
牛客练习赛31 D 神器大师泰兹瑞与威穆 https://ac.nowcoder.com/acm/contest/218/D 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 26214 ...
 - 最小生成树--牛客练习赛43-C
		
牛客练习赛43-C 链接: https://ac.nowcoder.com/acm/contest/548/C 来源:牛客网 题目描述  立华奏是一个刚刚开始学习 OI 的萌新. 最近,实力强大的 ...
 - 牛客练习赛28-B(线段树,区间更新)
		
牛客练习赛28 - B 传送门 题目 qn姐姐最好了~  qn姐姐给你了一个长度为n的序列还有m次操作让你玩,  1 l r 询问区间[l,r]内的元素和  2 l r 询问区间[l,r]内的 ...
 - 牛客练习赛26:D-xor序列(线性基)
		
链接:牛客练习赛26:D-xor序列(线性基) 题意:小a有n个数,他提出了一个很有意思的问题:他想知道对于任意的x, y,能否将x与这n个数中的任意多个数异或任意多次后变为y 题解:线性基 #inc ...
 - [堆+贪心]牛客练习赛40-B
		
传送门:牛客练习赛40 题面: 小A手头有 n 份任务,他可以以任意顺序完成这些任务,只有完成当前的任务后,他才能做下一个任务 第 i 个任务需要花费 x_i 的时间,同时完成第 i 个任务的时间不 ...
 - 牛客练习赛  29  E 位运算?位运算!(线段树)
		
题目链接 牛客练习赛29E 对$20$位分别建立线段树.首先$1$和$2$可以合起来搞(左移右移其实是等效的) 用个lazy标记下.转移的时候加个中间变量. $3$和$4$其实就是区间$01$覆盖操 ...
 - 牛客练习赛22C Bitset
		
牛客练习赛22C 一共有 n个数,第 i 个数是 xi xi 可以取 [li , ri] 中任意的一个值. 设 ,求 S 种类数. 感觉二进制真是一个神奇的东西. #include <iost ...
 
随机推荐
- Java并发编程原理与实战十九:AQS 剖析
			
一.引言在JDK1.5之前,一般是靠synchronized关键字来实现线程对共享变量的互斥访问.synchronized是在字节码上加指令,依赖于底层操作系统的Mutex Lock实现.而从JDK1 ...
 - 数据库日志文件(databasename_log.ldf)太大  如何清除
			
在SQL2008中清除日志就必须在简单模式下进行,等清除动作完毕再调回到完全模式.方案一:完全命令模式USE[master] GO ALTER DATABASE DNName SET RECOVERY ...
 - 用phpUnit入门TDD
			
用phpunit实战TDD系列 从一个银行账户开始 假设你已经 安装了phpunit. 我们从一个简单的银行账户的例子开始了解TDD(Test-Driven-Development)的思想. 在工程目 ...
 - Python读取Excel中的数据并导入到MySQL
			
""" 功能:将Excel数据导入到MySQL数据库 """ import xlrd import MySQLdb # Open the w ...
 - C++利用cin输入时检测回车的方法
			
今天做TJU的OJ ,其中一道题是先读入一个字符串,再读入一个整数,循环往复,直到字符串是空,也就是说回车键结束循环. 但是cin对空格和回车都不敏感,都不影响继续读入数据,所以需要一种新的方式检测回 ...
 - 用threading和Queue模块实现多线程的端口扫描器
			
一.Queue模块基础 q = Queue.Queue() q.qsize() 返回队列的大小 q.empty() 如果队列为空,返回True,反之Fals ...
 - DockerFile指令集
			
FROM 语法:FROM <image>[:<tag>] 解释:设置要制作的镜像基于哪个镜像,FROM指令必须是整个Dockerfile ...
 - C#   IsAssignableFrom与IsSubClassOf   判断匿名类是否继承父类
			
public class Dog : Animal { public string name { get; set; } } public class Animal { public string i ...
 - FPGA quartus开发中常见的错误处理
			
1.Warning: An incorrect timescale is selected for the Verilog Output (.VO) file of this PLL design. ...
 - Group Normalization笔记
			
作者:Yuxin,Wu Kaiming He 机构:Facebook AI Research (FAIR) 摘要:BN是深度学习发展中的一个里程碑技术,它使得各种网络得以训练.然而,在batch维度上 ...