https://www.luogu.org/problemnew/show/P4578

https://loj.ac/problem/2520

UPD 6.12 整体更新

前置:

先转换成图论模型,即每个绿宝石,横坐标向纵坐标连边,权值为绿宝石要的数。

然后就变成了每个点,我按一下可以使得与它相连的边都$+1/-1$,问能否使图边权全部变成$0$。

那么我们顺其自然的开个$del[i]$表示$i$这个点需要删多少次才能符合答案,显然的对于每条边$(u,v,w)$都要有$del[u]+del[v]==w$。

更进一步:

我们思考若原图为一棵树会不会好做些。

求证:对于连边情况为一棵树来说,当一个结点的$del$固定时,有且只有唯一解。

证明:令该节点为根,根层为$0$层,往下为$1$层,$2$层……

由$del[u]+del[v]==w$可知三个值知道两个即可求第三个,所以$0$层的$del$定下来后$1$层的就定了,之后$2$层的就定了……以此类推。

也因此,我们如果对根的$del+k$的话,那么对于每一奇数层$del$就要$-k$,每一偶数层就要$+k$。我们用这一性质可以构造出所有的解。

之后对于非树边,有且只有奇层与偶层的点连边这一种情况。(因为永远都是横纵相连,所以奇奇边和偶偶边是不存在的)

而又因为对于奇数层和偶数层非树边来说两点的$del$和永远不变(一个$+k$一个$-k$抵消了),所以通过它们与边权的比较我们就可以判断答案合法性。

以及我们也因此论证了对于最开始的$del$定什么都无所谓,所以就定$0$呗,何乐而不为呢?

后记:

题解最开始比较意识流,没有详细的证明,所以修正一下。

本人写这个博客时已经是退役一年OIER,因此如果有疏漏请指出。

不过这题作为为数不多自己做出来的省选题果然不算太难,毕竟意识流想法是对的所以反着证明就没有什么难度了……大概?

#include<cmath>
#include<stack>
#include<queue>
#include<cstdio>
#include<cctype>
#include<vector>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long ll;
const int N=2005;
inline ll read(){ll X=0,w=0;char ch=0;while(!isdigit(ch)){w|=ch=='-';ch=getchar();}while(isdigit(ch))X=(X<<3)+(X<<1)+(ch^48),ch=getchar();return w?-X:X;
}
struct node{int to,nxt,w;
}e[N];
int n,m,k,cnt,head[N],del[N];
bool vis[N];
queue<int>q;
inline void add(int u,int v,int w){e[++cnt].to=v;e[cnt].w=w;e[cnt].nxt=head[u];head[u]=cnt;
}
bool bfs(int s){while(!q.empty())q.pop();q.push(s);vis[s]=1;while(!q.empty()){int u=q.front();q.pop();for(int i=head[u];i;i=e[i].nxt){int v=e[i].to,w=e[i].w;if(vis[v]){if(del[u]+del[v]!=w)return 0;}else{del[v]=w-del[u];vis[v]=1;q.push(v);}}}return 1;
}
int main(){int T=read();while(T--){memset(vis,0,sizeof(vis));memset(head,0,sizeof(head));cnt=0;n=read(),m=read(),k=read();for(int i=1;i<=k;i++){int u=read(),v=read(),w=read();add(u,v+n,w);add(v+n,u,w);}bool ans=1;for(int i=1;i<=n+m;i++){if(!vis[i])ans&=bfs(i);}if(ans)puts("Yes");else puts("No");}return 0;
}

+++++++++++++++++++++++++++++++++++++++++++

+本文作者:luyouqi233。               +

+欢迎访问我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

转载于:https://www.cnblogs.com/luyouqi233/p/9145394.html

洛谷4578 LOJ2520:[FJOI2018]所罗门王的宝藏——题解相关推荐

  1. 洛谷P5520 [yLOI2019] 青原樱 题解

    洛谷P5520 [yLOI2019] 青原樱 题解 题目链接:P5520 [yLOI2019] 青原樱 题意: n n n 个空放 m m m 个物品,两两物品不能直接相邻,至少空一格 纯数学题. 看 ...

  2. 洛谷P5633 最小度限制生成树 题解

    洛谷P5633 最小度限制生成树 题解 题目链接:P5633 最小度限制生成树 题意: 给你一个有 n n n 个节点, m m m 条边的带权无向图,你需要求得一个生成树,使边权总和最小,且满足编号 ...

  3. 洛谷P2619 [国家集训队]Tree I 题解

    洛谷P2619 [国家集训队]Tree I 题解 题目链接:P2619 [国家集训队]Tree I 题意: 给你一个无向带权连通图,每条边是黑色或白色.让你求一棵最小权的恰好有 need\text{n ...

  4. 洛谷P1282 多米诺骨牌 题解

    洛谷P1282 多米诺骨牌 题解 题目链接:P1282 多米诺骨牌 题意: 多米诺骨牌由上下 222 个方块组成,每个方块中有 1∼61\sim61∼6 个点.现有排成行的上方块中点数之和记为 S1S ...

  5. 洛谷P4084 [USACO17DEC]Barn Painting G 题解

    洛谷P4084 [USACO17DEC]Barn Painting G 题解 题目链接:P4084 [USACO17DEC]Barn Painting G 题意:题意:给定一颗N个节点组成的树,3种颜 ...

  6. 洛谷P3237 [HNOI2014]米特运输 题解

    洛谷P3237 [HNOI2014]米特运输 题解 题目链接:P3237 [HNOI2014]米特运输 题意: 这题面是真的长啊 qwq 米特是D星球上一种非常神秘的物质,蕴含着巨大的能量.在以米特为 ...

  7. 洛谷P4315 月下“毛景树” 题解

    洛谷P4315 月下"毛景树" 题解 题目链接:P4315 月下"毛景树" 题意:请维护一个数据结构,支持 改第 kkk 条边的边权 结点 uuu 到 vvv ...

  8. 洛谷P3412 仓鼠找$Sugar\ II$题解(期望+统计论?)

    洛谷P3412 仓鼠找\(Sugar\ II\)题解(期望+统计论?) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1327573 原题链接:洛谷P3412 ...

  9. 洛谷P4287 [SHOI2011]双倍回文 题解

    洛谷P4287 [SHOI2011]双倍回文 题解 题目链接:P4287 [SHOI2011]双倍回文 题意: 记字符串 www 的倒置为 wRw^RwR .例如 (abcd)R=dcba(\tt{a ...

  10. 洛谷P5322 [BJOI2019] 排兵布阵 题解

    洛谷P5322 [BJOI2019] 排兵布阵 题解 题意:小 C 正在玩一款排兵布阵的游戏.在游戏中有 n n n 座城堡,每局对战由两名玩家来争夺这些城堡.每名玩家有 m m m 名士兵,可以向第 ...

最新文章

  1. 更改VS的默认开发语言
  2. iOS内存管理编程指南
  3. 忘记手机绑定过的UC/交易猫账号怎么找回
  4. html 悬浮阴影,css实现悬浮效果的阴影的方法示例
  5. 前端---JavaScript基础4
  6. 华科计算机课程设计,华中科大操作系统课程设计报告(附源码).doc
  7. Wince6.0p上用ASP技术实现Webserver
  8. AM335x关于LCD屏幕的时钟PLL配置
  9. 如果不清楚设计方向,圣诞设计模板可以帮助你轻松建立节日主题。
  10. 【Vue2.0】—过渡与动画(二十一)
  11. Infosys:印度信息技术巨头公司
  12. windows下安装Linux(Ubuntu)系统
  13. Oracle表中新增字段
  14. memcached入门
  15. 基于java的网络聊天室
  16. 基于深度信念网络的表示学习用于lncrna -疾病关联预测
  17. 手把手教用matlab做无人驾驶(二十三)--LMPC
  18. java解析excel文件详解_java解析excel文件的方法
  19. php扒皮,扒皮b站美妆up主兰花
  20. PostgreSQL的集群化和容器化部署

热门文章

  1. R语言-两总体均值对比
  2. 自动html5视频播放插件,视频自动转HTML5播放器插件
  3. 基于ZYNQ、AM5728、AM5708、AM437x、AM335x、STM32+FPGA等平台提供了开源EtherCAT主站IgH案例
  4. 关于win7 环境下安装docker容器的步骤 以及过程中的问题解决
  5. python中的异常、模块、文件
  6. 计算机中MAX函数是求什么,MAX函数
  7. win7装sql2000找不到服务器,WIN7 64位系统 SQL2000服务无法启动
  8. matlab消除多重共线性,多重共线性问题的几种解决方法-解决多重共线性的方法...
  9. c语言怎么写最小公倍数的函数,C语言 · 最小公倍数
  10. 计算机科学的主要目标,学习计算机的主要目的是什么?