题目链接

大意

给定一个\(N\times N\)的矩阵,问是否满足以下三个条件:

  1. \(A_{i,i}=0\)
  2. \(A_{i,j}=A_{j,i}\)
  3. 对于任意的\(i,j,k\),满足\(A_{i,j}\ge max(A_{i,k},A_{k,j})\)

如果满足条件输出MAGIC,否则输出NOT MAGIC

思路

首先,对于第一二两个条件,直接判就行了。

考虑第三个条件:

对于这个矩形,有个直观的想法就是建成一个完全图。

点\(i\)和点\(j\)间的边权就是\(A_{i,j}\),那么第三个条件就转化为了:

对于任意一个三元环的三条边\(A,B,C\)



就有以下式子:

\[\begin{cases}
A\ge max(B,C)\\
B\ge max(A,C)\\
C\ge max(A,B)
\end{cases}
\]

化简一下即为,\(A,B,C\)中的最大值等于\(A,B,C\)中的次大值。

考虑如何快速地判断每一个三元环:

我们从小到大加边,权值相同的边一起加入,那么在任意时刻,图像中的每个连通块一定都是一个完全图,否则就不满足条件。

  • 证明: 若图中的某个连通块不是一个完全图,那么一定会缺少一些边,形成如下图的例子:



    而又由于1,3之间的边一定会严格大于\(A,B\),则该三元环的最大值不等于次大值,即不满足上述条件。

对于判断加边后是否每个连通块都是完全图,我们可以用最小生成树的思想来做:

我们知道加完所有边后的图像是一个完全图,那么我们在加边时只用判断一下该边连接的两个点是否在同一连通块内就行了。如果在同一连通块内,就说明之前形成了一个缺边的非完全图,就直接不合法了。

注:权值相同的边一定要一起加入呀。

代码

其实一个就是Kruskal算法。

#include<map>
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
const int MAXN=2505;
int N,A[MAXN][MAXN],Len;
int Fa[MAXN],B[MAXN*MAXN],Cnt,NCnt;
struct Edge{int x,y,z;}s[MAXN*MAXN];
vector<int>P[MAXN*MAXN];map<int,int>Mp;
bool cmp(Edge A,Edge B){return A.z<B.z;}
int Find(int x){return Fa[x]==x?x:Fa[x]=Find(Fa[x]);}
int main(){
scanf("%d",&N);
for(int i=1;i<=N;i++)
for(int j=1;j<=N;j++)
scanf("%d",&A[i][j]);
for(int i=1;i<=N;i++){
if(A[i][i]){
printf("NOT MAGIC\n");
return 0;
}
for(int j=i+1;j<=N;j++){
if(A[i][j]!=A[j][i]){
printf("NOT MAGIC\n");
return 0;
}Len++;
s[Len].x=i;
s[Len].y=j;
s[Len].z=A[i][j];
B[++Cnt]=A[i][j];
}
}
sort(B+1,B+Cnt+1);
sort(s+1,s+Len+1,cmp);B[0]=-1;
for(int i=1;i<=Cnt;i++)
if(B[i]!=B[i-1])Mp[B[i]]=++NCnt;
for(int i=1;i<=Len;i++){
s[i].z=Mp[s[i].z];
P[s[i].z].push_back(i);
}
for(int i=1;i<=N;i++)Fa[i]=i;
for(int i=1;i<=NCnt;i++){
int size=P[i].size();
for(int j=0;j<size;j++){
int u=P[i][j];
int x=Find(s[u].x);
int y=Find(s[u].y);
if(x==y){
printf("NOT MAGIC\n");
return 0;
}
}
for(int j=0;j<size;j++){
int x=Find(s[P[i][j]].x);
int y=Find(s[P[i][j]].y);
if(x!=y)Fa[x]=y;
}
}
printf("MAGIC\n");
}

【CF632F】Magic Matrix(生成树 脑洞)的更多相关文章

  1. 【思维题 经典模型】cf632F. Magic Matrix

    非常妙的经典模型转化啊…… You're given a matrix A of size n × n. Let's call the matrix with nonnegative elements ...

  2. CF 1042 E. Vasya and Magic Matrix

    E. Vasya and Magic Matrix http://codeforces.com/contest/1042/problem/E 题意: 一个n*m的矩阵,每个位置有一个元素,给定一个起点 ...

  3. Educational Codeforces Round 9 F. Magic Matrix 最小生成树

    F. Magic Matrix 题目连接: http://www.codeforces.com/contest/632/problem/F Description You're given a mat ...

  4. Codeforces 632F Magic Matrix(bitset)

    题目链接  Magic Matrix 考虑第三个条件,如果不符合的话说明$a[i][k] < a[i][j]$ 或 $a[j][k] < a[i][j]$ 于是我们把所有的$(a[i][j ...

  5. codeforces 632F. Magic Matrix (最小生成树)

    You're given a matrix A of size n × n. Let's call the matrix with nonnegative elements magic if it i ...

  6. codeforces 632F. Magic Matrix

    题目链接 给一个n*n的矩阵, 问是否对角线上的元素全都为0, a[i][j]是否等于a[j][i], a[i][j]是否小于等于max(a[i][k], a[j][k]), k为任意值. 前两个都好 ...

  7. Codeforces 632F - Magic Matrix(暴力 bitset or Prim 求最小生成树+最小瓶颈路)

    题面传送门 开始挖老祖宗(ycx)留下来的东西.jpg 本来想水一道紫题作为 AC 的第 500 道紫题的,结果发现点开了道神题. 首先先讲一个我想出来的暴力做法.条件一和条件二直接扫一遍判断掉.先将 ...

  8. CF1042E Vasya and Magic Matrix

    感觉不会期望. 首先把所有格子按照权值从小到大排一下序,这样一共有$n * m$个元素,每个元素有三个属性$x, y, val$. 下文中的下标均为排序后的下标. 这样子我们就可以推出公式: $f_i ...

  9. Vasya and Magic Matrix CodeForces - 1042E (概率dp)

    大意:给定n*m矩阵, 初始位置(r,c), 每一步随机移动到权值小于当前点的位置, 得分为移动距离的平方, 求得分期望. 直接暴力dp的话复杂度是O(n^4), 把距离平方拆开化简一下, 可以O(n ...

随机推荐

  1. C语言 Make命令教程

    make只是一个根据指定的Shell命令进行构建的工具 在linux和unix中,有一个强大的使用程序,叫make,可以用它来管理多模块程序的编译和链接,直至生成可执行文件 make使用程序读取一个说 ...

  2. Linux_接收文件(rz)和发送文件(sz)

    我们连接linux通常是使用一些ssh工具进行远程访问连接的,在使用过程中,少不了将本地文件上传到linux或将linux上的文件下载到本地,每次使用ftp比较繁琐而且浪费时间.我们可以使用linux ...

  3. .net core 和 WPF 开发升讯威在线客服系统:调用百度翻译接口实现实时自动翻译

    业余时间用 .net core 写了一个在线客服系统.并在博客园写了一个系列的文章,写介绍这个开发过程. 我把这款业余时间写的小系统丢在网上,陆续有人找我要私有化版本,我都给了,毕竟软件业的初衷就是免 ...

  4. test_3 简单密码破解

    题目描述:密码是我们生活中非常重要的东东,我们的那么一点不能说的秘密就全靠它了.哇哈哈. 接下来渊子要在密码之上再加一套密码,虽然简单但也安全. 假设渊子原来一个BBS上的密码为zvbo9441987 ...

  5. GNU C字节对齐__attribute__((aligned(n))) #pragma pack(n)

    在阅读gnu软件c源代码时,经常会遇到字节对齐相关操作,比如uboot命令相关的代码中,会遇到__attribute__((aligned(n)))扩展关键字,#pragma pack(n)预处理指令 ...

  6. 局域网内部怎么安全接入U盘?

    准备工具: 内部专用U盘一个: 能连接外网的电脑(暂称"安全机")一个. 第一.安全机上安装360杀毒.360安全卫士或其它安全软件.并经常更新病毒库.木马库. 第二.外来U盘先通 ...

  7. Android一句话 | ViewGroup事件分发

    ViewGroup中可重写的关于事件分发的事件有dispatchTouchEvent,onTouchEvent,onInterceptTouchEvent和requestDisallowInterce ...

  8. 《剑指offer》面试题05. 替换空格

    问题描述 请实现一个函数,把字符串 s 中的每个空格替换成"%20". 示例 1: 输入:s = "We are happy." 输出:"We%20a ...

  9. LaTex 中圆圈序号及一些特殊字符的输入

    众所周知,LATEX 提供了 \textcircled 命令用以给字符加圈,但效果却不怎么好: 实际上,加圈并不是一个平凡的变换,它会涉及到圈内字符形状的微调,而这是几乎无法在 TEX 宏层面解决的. ...

  10. 【刷题-LeetCode】151 Reverse Words in a String

    Reverse Words in a String Given an input string, reverse the string word by word. Example 1: Input: ...