题面

这也算是个套路题(算吗)?发现换来换去每行每列数的组成是不变的,那么就把每行每列拎出来哈希一下,复杂度$O(Tn^2log$ $n)$有点卡时=。=。

然而正解似乎不需要哈希,就像这样↓

  1. for(int i=;i<=n;i++)
  2. for(int j=;j<=m;j++){
  3. int xxx=read();
  4. x[xxx+A]=i;
  5. y[xxx+A]=j;
  6. }
  7. bool b=true;
  8. for(int i=;i<=n;i++){
  9. for(int j=;j<=m;j++){
  10. a[i][j]=read();
  11. if(x[a[i][j]+A]!=x[a[i][]+A]||x[a[i][j]+A]==)b=false;
  12. if(y[a[i][j]+A]!=y[a[][j]+A]||y[a[i][j]+A]==)b=false;
  13. }
  14. }

(来自洛谷题解,侵删)

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<algorithm>
  4. #define ull unsigned long long
  5. using namespace std;
  6. const int N=,P=1e6;
  7. const long long bas=;
  8. ull tmp[N],hsh[][*N];
  9. int mapp[N][N],n,m,T;
  10. int main ()
  11. {
  12. register int i,j,k;
  13. scanf("%d",&T);
  14. while(T--)
  15. {
  16. scanf("%d%d",&n,&m);
  17. memset(hsh,,sizeof hsh);
  18. for(k=;k<=;k++)
  19. {
  20. for(i=;i<=n;i++)
  21. for(j=;j<=m;j++)
  22. scanf("%d",&mapp[i][j]),mapp[i][j]+=P;
  23. for(i=;i<=n;i++)
  24. {
  25. for(j=;j<=m;j++)
  26. tmp[j]=mapp[i][j];
  27. sort(tmp+,tmp++m);
  28. for(j=;j<=m;j++)
  29. hsh[k][i]=hsh[k][i]*bas+tmp[j];
  30. }
  31. for(i=;i<=m;i++)
  32. {
  33. for(j=;j<=n;j++)
  34. tmp[j]=mapp[j][i];
  35. sort(tmp+,tmp++n);
  36. for(j=;j<=n;j++)
  37. hsh[k][i+n]=hsh[k][i+n]*bas+tmp[j];
  38. }
  39. }
  40. sort(hsh[]+,hsh[]++n+m);
  41. sort(hsh[]+,hsh[]++n+m);
  42. bool f=true;
  43. for(i=;i<=n+m&&f;i++)
  44. if(hsh[][i]!=hsh[][i]) f=false;
  45. f?printf("TAK\n"):printf("NIE\n");
  46. }
  47. return ;
  48. }

解题:POI 2009 TAB的更多相关文章

  1. 解题:POI 2009 Fire Extinguishers

    题面 洛谷数据非常水,建议去bzoj 我第一眼一看这不是那个POI2011的升级版吗(明明这个是2009年的,应该说那个是这个的弱化版,果然思想差不多. 因为$k$很小,可以考虑每个间隔距离来转移.我 ...

  2. 解题:POI 2009 Ticket Inspector

    题面 看起来很水,然而不会DP的蒟蒻并不会做,PoPoqqq orz 设$f[i][j]$表示当前在第$i$个点和第$i+1$个点之间查票,已经查了$j$次的最大收益.然后就是那种很常见的枚举前一个结 ...

  3. 解题:POI 2009 Lyz

    题面 板板讲的霍尔定理 霍尔定理:一张二分图有完全匹配的充要条件是对于任$i$个左部点都有至少$i$个右部点与它们相邻.放在这个题里就是说显然最容易使得鞋不够的情况是一段连续的人,那就维护一下最大子段 ...

  4. [POI 2009]Lyz

    Description 题库链接 初始时滑冰俱乐部有 \(1\) 到 \(n\) 号的溜冰鞋各 \(k\) 双.已知 \(x\) 号脚的人可以穿 \(x\) 到 \(x+d\) 的溜冰鞋.有 \(m\ ...

  5. 【BZOJ 1115】【POI 2009】石子游戏Kam

    http://www.lydsy.com/JudgeOnline/problem.php?id=1115 差分后变成阶梯博弈. #include<cstdio> #include<c ...

  6. 【Nim 游戏】 学习笔记

    前言 没脑子选手随便一道博弈论都不会 -- 正文 Nim 游戏引入 这里给出最简单的 \(Nim\) 游戏的题目描述: \(Nim\) 游戏 有两个顶尖聪明的人在玩游戏,游戏规则是这样的: 有\(n\ ...

  7. 解题:POI 2016 Nim z utrudnieniem

    题面 出现了,神仙题! 了解一点博弈论的话可以很容易转化题面:问$B$有多少种取(diu)石子的方式使得取后剩余石子异或值为零且取出的石子堆数是$d$的倍数 首先有个暴力做法:$dp[i][j][k] ...

  8. 解题:NOI 2009 诗人小G

    题面 今天考试考了,于是开始糊学决策单调性DP 这是一个完全不会优化DP的人 决策单调性DP的一种优化方法是用单调队列优化 存下{左端点l,右端点r,最优决策点p}的三元组,按照单调队列的通常操作来说 ...

  9. 解题:NOI 2009 管道取珠

    题面 考虑这个平方的实际意义,实际是说取两次取出一样的序列 那么设$dp[i][j][k][h]$表示第一次在上面取$i$个下面取$j$个,第二次在上面取$k$个下面取$h$个的方案数 等等$n^4$ ...

随机推荐

  1. access数据库频繁读取操作会出现 System.Data.OleDb.OleDbException 的异常解决

    asp.net access数据库 本来想着打开一个access数据库连接后,不关闭,下次操作数据了,直接拿来用,谁知道连着测试64次后(大概这么多次),就会出现System.Data.OleDb.O ...

  2. 5个最优秀的微信小程序UI组件库

    开发微信小程序的过程中,选择一款好用的组件库,可以达到事半功倍的效果.自从微信小程序面世以来,不断有一些开源组件库出来,下面5款就是排名比较靠前,用户使用量与关注度比较高的小程序UI组件库.还没用到它 ...

  3. CSS3实现图片渐入效果

    很多网站都有那种图片渐入的效果,如:http://www.mi.com/minote/,这种效果用css3和一些js实现起来特别简单. 拿我之前做的页面来说一下怎么利用css3来实现图片渐入效果. 下 ...

  4. 关于requestanimationframe

    首先字面理解,请求动画框架, 用法: var nextFrame = (function() { return window.requestAnimationFrame || window.webki ...

  5. 英文Datasheet没那么难读

    话说学好数理化,走遍天下都不怕.可是在这个所谓的全球化时代,真要走遍天下的话,数理化还真未必比得上一门外语.作为技术人员,可以看到的是目前多数前沿的产品和技术多来自发达的欧美等国家,而英语目前才是真正 ...

  6. “Hello World!”团队第五周第三次会议

    今天是我们团队“Hello World!”团队第五周召开的第三次会议. 双十一大家过的怎么样?由于组内其他成员被“剁手”,今日会议记录由我来写. 博客内容: 一.会议时间 二.会议地点 三.会议成员 ...

  7. Android数据储存之SQLiteDatabase 简单增删改查

    SQLiteDatabase 使用 SQLiteDatabase提供如下方法来打开一个文件对应的数据库: openDatabase(String path, SQLiteDatabase.Cursor ...

  8. 使用docker国内镜像解决方案

    1:蜂巢镜像 https://c.163yun.com/hub#/m/library/ 例如: docker pull hub.c.163.com/library/nginx:1.8 再次执行dock ...

  9. Qt多线程-QThreadPool线程池与QRunnable

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:Qt多线程-QThreadPool线程池与QRunnable     本文地址:https:/ ...

  10. Django之ORM其他骚操作

    Django ORM执行原生SQL # extra # 在QuerySet的基础上继续执行子语句 # extra(self, select=None, where=None, params=None, ...