【bzoj1567】Blue Mary的战役地图

题目

Description

Blue Mary最近迷上了玩Starcraft(星际争霸) 的RPG游戏。她正在设法寻找更多的战役地图以进一步提高自己的水平。 由于Blue Mary的技术已经达到了一定的高度,因此,对于用同一种打法能够通过的战役地图,她只需要玩一张,她就能了解这一类战役的打法,然后她就没有兴趣再玩儿这一类地图了。而网上流传的地图有很多都是属于同一种打法,因此Blue Mary需要你写一个程序,来帮助她判断哪些地图是属于同一类的。 具体来说,Blue Mary已经将战役地图编码为n*n的矩阵,矩阵的每个格子里面是一个32位(有符号)正整数。对于两个矩阵,他们的相似程度定义为他们的最大公共正方形矩阵的边长。两个矩阵的相似程度越大,这两张战役地图就越有可能是属于同一类的。
Input

第一行包含一个正整数n。 以下n行,每行包含n个正整数,表示第一张战役地图的代表矩阵。 再以下n行,每行包含n个正整数,表示第二张战役地图的代表矩阵。
Output

仅包含一行。这一行仅有一个正整数,表示这两个矩阵的相似程度。
Sample Input
3
1 2 3
4 5 6
7 8 9
5 6 7
8 9 1
2 3 4

Sample Output
2

注:两个矩阵相似度为两个矩阵最大公共子矩阵(子矩阵为正方形)的边长。

思路

这题其实比较简单
先预处理处理一下二维哈希的值
哈希矩形的子矩阵
然后二分答案(二分矩形的边长)
判断每一个mid是否符合
用的check函数再加hash子矩阵的值
就可判断是否出现进行二分

代码

#include <bits/stdc++.h>
#define N 101
#define ll unsigned long long
#define heng 1333
#define zong 23333
using namespace std;
map<ll,bool>s;
ll a[N][N],b[N][N],n;
ll f1[N],f2[N];
const ll mo=1e9+7;
inline bool check(int ans)
{ s.clear(); for(int i=ans;i<=n;++i){ for(int j=ans;j<=n;++j){ ll h = a[i][j]; h-=a[i-ans][j]*f1[ans]; h-=a[i][j-ans]*f2[ans]; h+=a[i-ans][j-ans]*f1[ans]*f2[ans]; s[h]=true; } } for(int i=ans;i<=n;++i){ for(int j=ans;j<=n;++j){ ll h = b[i][j]; h-=b[i-ans][j]*f1[ans]; h-=b[i][j-ans]*f2[ans]; h+=b[i-ans][j-ans]*f1[ans]*f2[ans]; if(s[h]==true)return true; } } return false;
}
int main()
{ scanf("%lld",&n); for(int i=1;i<=n;++i){ for(int j=1;j<=n;++j){ scanf("%lld",&a[i][j]); } } for(int i=1;i<=n;++i){ for(int j=1;j<=n;++j){ scanf("%lld",&b[i][j]); } } for(int i=1;i<=n;++i){ for(int j=1;j<=n;++j){ a[i][j]+=a[i-1][j]*heng; b[i][j]+=b[i-1][j]*heng; } } for(int i=1;i<=n;++i){ for(int j=1;j<=n;++j){ a[i][j]+=a[i][j-1]*zong; b[i][j]+=b[i][j-1]*zong; } } f1[0]=f2[0]=1; for(int i=1;i<=n;++i){ f1[i]=f1[i-1]*heng; f2[i]=f2[i-1]*zong; } int l=0,r=n; while(l<r-1){ int mid=(l+r)>>1; if(check(mid)) l=mid; else r=mid; } int p=max(l,r); if(check(p))cout<<p; else cout<<min(l,r); return 0;
}
就是这样,诶嘿嘿

【bzoj1567】【jsoi2008】【二分+哈希】Blue Mary的战役地图相关推荐

  1. BZOJ 1567: [JSOI2008]Blue Mary的战役地图( 二分答案 + hash )

    二分答案, 然后用哈希去判断... ------------------------------------------------------------------------- #include ...

  2. bzoj 1567: [JSOI2008]Blue Mary的战役地图 二维哈希

    1567: [JSOI2008]Blue Mary的战役地图 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 1199  Solved: 702 [S ...

  3. BZOJ 1567: [JSOI2008]Blue Mary的战役地图

    二次联通门 : BZOJ 1567: [JSOI2008]Blue Mary的战役地图 /*BZOJ 1567: [JSOI2008]Blue Mary的战役地图社会我栋哥人怂P话多暴力能A题正解能W ...

  4. BZOJ 1567: [JSOI2008]Blue Mary的战役地图 矩阵二维hash

    1567: [JSOI2008]Blue Mary的战役地图 Description Blue Mary最近迷上了玩Starcraft(星际争霸) 的RPG游戏.她正在设法寻找更多的战役地图以进一步提 ...

  5. [JSOI2008]Blue Mary的战役地图(二分+哈希)

    Blue Mary最近迷上了玩Starcraft(星际争霸) 的RPG游戏.她正在设法寻找更多的战役地图以进一步提高自己的水平. 由于Blue Mary的技术已经达到了一定的高度,因此,对于用同一种打 ...

  6. B1567 [JSOI2008]Blue Mary的战役地图 二分答案+hash

    一开始以为是dp,后来看了一下标签...二分答案?之前也想过,但是没往下想,然后之后的算法就顺理成章,先求出第一个地图的所有子矩阵的hash值,然后求第二个,在上一个地图例二分查找,然后就没了. 算法 ...

  7. [JSOI2008] [BZOJ1567] Blue Mary的战役地图 解题报告 (hash)

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1567 Description Blue Mary最近迷上了玩Starcraft(星际争霸 ...

  8. 1567: [JSOI2008]Blue Mary的战役地图

    Description Blue Mary最近迷上了玩Starcraft(星际争霸) 的RPG游戏.她正在设法寻找更多的战役地图以进一步提高自己的水平. 由于Blue Mary的技术已经达到了一定的高 ...

  9. [JSOI2008]Blue Mary的战役地图 Hash题解

    题目描述 Blue Mary最近迷上了玩Starcraft(星际争霸) 的RPG游戏.她正在设法寻找更多的战役地图以进一步提高自己的水平. 由于Blue Mary的技术已经达到了一定的高度,因此,对于 ...

最新文章

  1. Python pip安装第三方库的国内镜像
  2. 基于MVC4+EasyUI的Web开发框架经验总结(13)--DataGrid控件实现自己主动适应宽带高度...
  3. 【深度学习的数学】超平面是什么?(自由度比空间维度小1)
  4. IO 延迟与Queue Depth
  5. sap gateway data provider - /IWFND/IF_MGW_CORE_RUNTIME
  6. crontab 执行php脚本,为什么crontab没有执行我的PHP脚本?
  7. Windows破解笔记-windows API中的SendMessage
  8. Java 获取命令行输入数据(命令行输入,Scanner类)
  9. Python与机器视觉(x) 颜色直方图
  10. python pywinauto 单击鼠标_Python释放你的双手去成就梦想之自动化控制鼠标键盘
  11. 登峰连接程式改坐标软件_数控仿真软件CIMCOEdit常用的操作,新手必看
  12. 【白皮书分享】2021智慧零售私域白皮书-腾讯.pdf(附下载链接)
  13. LeetCode(876)——链表的中间结点(JavaScript)
  14. 【php】基础学习4
  15. 探究:数字孪生是如何赋能智慧能源信息化领域系统发展的?
  16. Java编程语言的重要性
  17. 计算机病毒结构及技术分析
  18. 使用C语言播放一首音乐
  19. Hi3512的IPCAM开发
  20. oracle 11g duplicate database基于备份复制数据库(一)

热门文章

  1. 6种互联网创业副业策略
  2. 学python多大年龄可以学车_考驾照最大多少多大年龄可以报名
  3. python如何实现飞机上下移动_python实现飞机大战
  4. 国内各大厂ChatGPT技术布局及应用场景
  5. 【笑话】一个预备老公的转正申请
  6. 【OpenCV-Python】——哈里斯/Shi-Tomas角检测FAST/SIFT/ORB特征点检测暴力/FLANN匹配器对象查找
  7. python保留2位小数输出的简单方法(秒懂)
  8. 【KMRE全新升级】玩法更多、应用更全、体验更好
  9. 倍福XTS | 磁驱柔性输送系统环形线Ethercat DSP+FPGA控制器
  10. 支付系统设计三:渠道网关设计02-客户端报文解析