hdu 3038(扩展并查集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3038
题意:给出区间[1,n],下面有m组数据,l r v区间[l,r]之和为v,每输入一组数据,判断此组条件是否与前面冲突 ,最后输出与前面冲突的数据的个数.
比如 [1 5]区间和为100 然后后面给出区间[1,2]的和为 200 那肯定就是有问题的了。
极力推荐这位大牛的博客:http://blog.csdn.net/niushuai666/article/details/6981689
这题让我学到了很多,特别是关于向量偏移,可以直接找到根节点与子节点的关系
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAY0AAAFMCAIAAAC4cXeXAAAPi0lEQVR4nO3d23nyuBqAUQqZy6mCgqiHamiGGqYG5sIJ8UE+G/xJWuv5bwYMsSX5jSHszeUFENvl7B0AmKFTQHQ6BUSnU0B0OgVEp1NAdDoFRKdTQHQ6BUSnU0B0OgVEp1NAdDoFRKdTQHQ6BUSnU0B0OgVEp1NAdDoFRKdTQHQ6BUSnU0B0OgVEp1NAdDoFRKdTQHSZdOpxu1xuj/5N1/szse3zfn3f8bhdEnrPNHiu5/063CbxY+Y3Ag6QR6eGTZqoRK9TSx64tVMJ6XYCO4Tv1CAH1/szdZ3014eFnUpfaiUlm/XV66nE9STUI4tO/Z2hTXcGZ+1PjvrpuT1Ked2nU1QtVKfa106/Z+WwU9fr5HtVz/v1svZ13/rdm7nwetwul+v90Tygs2vjtRy5t/dTf58sNVZQqECdet5vnRO6OSNT11ODh7Zuftyu1+v77J3s1JJXfu0ETCeuc+/PU7e3ftw6N7QOcf7ewfVUeqygUIE61fE+MdPvT/WS8c7R83693Zv3p5736/V+X/a6byRBj9uuTvUrlSjmzzbT975mXvd5UUjpYnWqe4Xz7lTyeqp1bv9u07yDnngfvf/+07N/9ZFMUP/G1a/7uu94DX7Ae6Ppe3//Y/hadzK9UI44nWrOu9/zrXM9Nfa673ej320et79adbdvlSx5Wi/q1MqD+WCnRsYKChWmU90z++/MXfL+VHeb9OcSxgqVeobEE/082fsTDX9vcbWu77pvN/Ufe9zrvrGxgkKF6tTv2fbTlDWdat2a7NTj1nxIYfyzoclrrPRb2d334tt/gWtf4nR3tDmmbmv6f9Qbu7f/fGNjBYUK06n22z/tj0il30cfPHC8U51HPW7JZ/hrTOfHdZ+09+e45r9GPgWRuEBq703yOJbd+/dX0OFYQaECdSpt7Hpq/KxudSp5BqdeJ829FdW/jvt74k6o+q8UgSOE7xRQPZ0CotMpIDqdAqLTKSA6nQKi0ykgOp0CotMpIDqdAqLTKSA6nQKi0ykgukCdSv9/ofS38K3If+ZHDIqQU6d8K3KPTlGJTDrlW5Ffr+H1pE5RiYw65VuRdYpKxetU8ot+fSty6luRp0YMChKsU4PzufcNfe8tfSvyzIhBQaJ1qlOA7rdjdfhW5JkRg4IE61TvNO18E6dvRV7w/pS3rChR7p16VfytyDpFLYJ1avAHvNb31flW5PnXfTJFkaJ1qndWJr6B+OVbkTv3j4xYbhSWCcE69f4rfu+qx7cid+9tfy4hPWK50SkmBOrUFN+KXBqfWWWFTDpFaXSKFXSKRXy2nhPpFIv4bD0n0ikW8dl6TqRTLOIzq5xIp1hEpziRTrGIz9ZzIp1iEZ+t50Q6xSI+W8+JdAqITqeA6HSKP+2PiR/yPEftGJWzkvhxmbT5eT63w9TDMuLHdKeW1Gfbo2CWpcOPVZ0a1mfzw1WMWRYHf/a35nBnDwkhWAeknR2oP2ePBOezCFhEpziRRcAW23KjU2xjEbDah3IjUoyxDlhnW6REhz0sHVbYEymdYjNLh0WWl0iqOJx1w7zlVZrYWKfYzLphxnRx1nZKqtjAomHKbGtmO5W8BVaxaEhbeDW0oVNSxVpWDAmbI7XqRljIiqFvYaSGWy6/UapYxXLhz1ihxrKy6tJJp9jMcuHHqkIlHzJxY/L5P3s8FMRa4fXaFKnhoyZunL0LJlgrHBmpiduTP+gjx0NxLJSqbStU8rGzty+5F5IslHrtidTw4bO3j/3Qw46HclklldoZqeEzzN6+fAPosUqqM1aotck4qlNSxSxLpC6HFGr4PAvvWrUNvFkiFTkqUsOnWnjXxJ5sOR6qYX1UYaxQmwMx/SRLnlynWM76KN+xhUo+5yF7tWd/KJvFUbhPRKr3zEft2/5dolQWR8k+F6lDhN0xorEyyhS8UG/Bd48grIwC5RKpl0sqlrEsSpNRpBq57CcnsizKMVao4Cd/XnvLKayJQuRYqLcc95lvsiZKkHWkXi6pmGNBZC/3SDWy3nk+zYLIWBmFapRxFHyI1ZCrkiLVKOZAOJzVkKXyIvVyScU4SyEzY4Uq46wu74g4hKWQk4IL1Sj40NjDOshG8ZFqlH10bGMd5KGSSL1cUpFiEURXT6He6jlSFrIIQqswUi+XVAxYAXHVGalGhYfMBCsgopoL1aj52Bky/eGIVKPyw6fN9MciUm8GgTdzH8VYoWo+P40DDXMfgkIlGRAaJv7tcbtcbo8TfrBITTAmvHSq5ZxOidQ0I8Mr6049bpfL9f64Xy+Xy+V6fza3Ppv//tHvzsi93ZvfT9a++fiCKdRCxoeMZ/1xGwTkcevc8LxfWwWbuXdwPfW83zrxa226n0gtZ5TIeMp72fm9wOrE5Hm//m4zfe9r5nXfoS8KRWotA1W5jKe8H55udfobTd/7+x+9DX4u2Y576TdWKOfeNMNVuYzn+8Odahr1e8MR11MKtYdBq1nG8z14IXfo677u5snKrSJSOxm6mmU82cPwNH+f67am/0e9sXv7z9e+9+fvfts7JVKHMHrVyniyExdIr95bSoO7l93b3PH3qYTr/bn1dZ9CHcgwVstMf5BIHc5I1slMf4pIfYLxrJNpPt5YoZxUhzCkFTLNB1OoTzO2FTLHx5i4hnIiHc7w1sYcH0Ckvswg18YEH0Chvs9QV8UE7zUbKafTJ/itUBWzu9H0a733abNkG7YxmPUwu+vM5ql92izf2Gm2gTGsh6mdtyo3Rzn7oPNg0Cphakedkqeks0ciLmNVCfPa9/0MrXL28IRjfGpgXjtOSc9aZw9SLManBia1Y1Ujhnclt1/yhLM/d2wfeLmkqoBJ7ViVhiXFmX7asefXqVUMUfHMaN/C5T52boydMLOpmvhxzsBZOlU2M7rR8h6N3b62VkwwjGUznRtNnBXLE6ZWBzKABTOdW0xnZfldanUgo1cwc7nF9PmwqlPJG51v2xi3UpnLLWbPh+WpGrtdrTYwaKUykastORmWd2r23k+eeK2vCRt+w1iedKpIJnK1JWfC9DZrM/eRc+9xu3S/8fm+82vpY/hw2TmHWVxtQ6cuay6pJjY77vTb/0X0celUecziOsvPgektl3fnI7UqOVMuqQpkCtf5fqeSG+89D4vu1MslVXFM4Qo747Ln2ZLb7zgbH7dy3jpPOCDlRGL+Vli79Ge333AuHVWr5/16aV9SPW6FXV7pVEnM3wqf7tTy0+mYWrU+llDei8DNY0tAJm+pDet+yfZ7zqVjalUuo1EMk7fUtkU/u/3+c0mtxhiKYpi5pT634g95TqlKMg5lMHOL5HLmq1WPQSiDaVskr7WuVm2VH34ZTNsi2a316VRlcQhHqfnYi2HO5uW70NWqUedRl8Sczct9latVhYdcGBM2r4wlXnmtqjrY8piwGYWt72prVc+RFslszShycddZqxqOsVRma0rZJ3BtqarhGEtlqqbUsKyrqlXZR1cwUzWlnmVdSa0KPrSymadRta3p6VQVc/hFHlTxzNOoOhd08bUq74hqYJJG1byay65VScdSCZOUVtiZuU2ptSrmQOphhtKs47cia1XAIVTFDKVZxz2F1Sr3/a+N6UmwiMcUnKqzd4cppifBCp5WRq3y3fMKmZsEy3eJAmqV4z7Xydz0WbvLTacq/uhlt8PVMjF9Fu5aWdcqo12tmYnpyOscCyXTWuWyn5UzKx2W7E451ir+HmJWOizZQ+RVq+C7x0un2qzXY2VUq7A7RsOU/LFYPyGLVIXdMRrm44+V+jnxaxVwl3gzHz9injyFiVyraPtDm8n4YY1+x3Sqzh35OHtCj8n4YY1+U8xaBdkNhszE62WBniRgrU7fAZLMxOtldZ4qVK0itJIh0/B66VQAcWplMQRkGvwKDSRCrayHgMyB35/hREvVF34i08yBRRnUibVySRVN7RNgOQZ3Vq0sjFBqnwDLMb7pVH1o1lxShVL16FuLGfl+rayNOKoefQsxO9+slV9jcVQ99FZhpr5WKyskiHqH3m/L3H2hVhZJEPWOu/VXhk/XyjqJoN5xt/5K8rlUuaSKoNJBt/iK9KFaWSqnq3TQrbyCHV4rv9VOV+mIW3Zlm07Vhhm3YM5V44j79ViJA2tlzZyrxuG24KpyVK0smxPVONwWXIX218ol1YmqG2tLrWY7a2XxnKW6sbbU2Fwrl1RnqWugrTPeDknVN3e4ZnUNtEVGz9pa+VV3irpG2QojaVWtrKLvq2iU/SYk6b9//v3vn3+nU9VeLRbS91U0xNYWQ02k3v8W1spa+rKKhtjaYqjXqSW1ermk+rpaxtfCIinZqelaNQ+0nL6plvG1qhgzkapkrZpH+c33TbUMriXFtIW1aj/EovqaKgbXrz4Wmq5V8++9sXX1NVWMrMXEKktq1QTL0vqOKkbWYmKbJbWyur6g/GF1cc5Oq2p19s6WqfxhFSkOsbxWZ+9pgcofU51i2sJ3oxb+s8Y+ofAxFakKHdudDZ2y0g5X+IDqVBnOTY9Ona7kAfUOelin1+SjkbLSDlfygIrU15weiK/9Sx6+lfZpJY+p1bPH6UU4sTurWGZfUOywetHXc3oRMkrPcpbZdxQ7rDWsntOLUF53VhlGqtSVdrpihzXH1XN6ESrvznLJQuWyzHJU5sgGWUCnF0F6PkGkvq/Mwf3cAjq9CLpzLpE6RZnju3wNnV4E6cmISJ2lwCHuraHTA6E7ZdhQqMftcrnen9/Zv6IV3qnTa6I7Zdh2GaVTR9Ep6WHKntd6OnWUAjv1aq0t3WGPnW9I6dRRyuxUm+6wzc5Ivd6det6v7wffHp/b4YKV3ynYYH+kXk2nLq1Lquf96gJrE52ChJ2Fajxu/Suo5/3qmmoDnYKE/ZF6Jd+f8pbVJjoFaTsj9dKp4+gUfMrwdZ9MbaNT8Ck/76O/SzXsFsvoFHxKc/X08LGE3XLplI+gQL3y6NTzfvMRFKhWHp3qeNxcUkFVsunUz1uSXvpBfbLoVNOo3za5noLK5NCp7mdO/C8PoDa5dOq3TD9/99MpqEgOnWp/KuF6f3rdB5XJo1NAzXQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4DodAqITqeA6HQKiE6ngOh0CohOp4Do/gcBSYLaE1UYqwAAAABJRU5ErkJggg==" alt="" width="262" height="220" />
这题我们利用一个sum[]数组保存从某点到其祖先节点距离。
1.从上图我们可以看出,当roota!=rootb时 如果将roota并入rootb,那么是不是 roota->rootb = b->rootb - b->roota
然后我们可以知道 b->roota = a->roota - a->b
所以最后可以推出 roota ->rootb = b->rootb + a->b - a->roota
而roota的根节点是rootb,所以 roota->rootb = sum[roota]
然后依次推出得到 sum[roota] = -sum[a]+sum[b]+v (这里的a要说明一下由于是区间 [a,b] ,[a,b] = [root,b]-[root,a-1],所以a要减一)
aaarticlea/png;base64,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" alt="" width="210" height="178" />
2.如果roota==rootb 是不是 a和b的根节点已经相同了?所以我们只要验证 a->b是否与题中的长度一致了。
所以 a->b = a->root - b->root
然后得到表达式 v = sum[a]-sum[b] (一定要记住这里的sum都是相对于根节点的,sum的更新在路径压缩的时候更新了)
这样说是不是懂了向量偏移的思想呢??
下面上代码:
#include <stdio.h>
#include <algorithm>
#include <string.h>
using namespace std;
const int N =;
int father[N];
int sum[N]; ///记录当前结点到根结点的距离 int _find(int x){
if(x!=father[x]){
int t = father[x];
father[x] = _find(father[x]);
sum[x]+=sum[t];
}
return father[x];
}
int main()
{
int n,m;
while(scanf("%d%d",&n,&m)!=EOF){
for(int i=;i<=n;i++){
father[i] = i;
sum[i] = ;
}
int ans = ;
while(m--){
int a,b,v;
scanf("%d%d%d",&a,&b,&v);
a--;
int roota = _find(a);
int rootb = _find(b);
if(roota==rootb){
if(sum[a]-sum[b]!=v) ans++; ///精华部分1
}
else{
father[roota] = rootb;
sum[roota] = -sum[a]+sum[b]+v; ///精华部分2
}
}
printf("%d\n",ans);
}
return ;
}
hdu 3038(扩展并查集)的更多相关文章
- HDU - 3038 种类并查集
思路:种类并查集的每个节点应该保存它的父节点以及他和父节点之间的关系.假设root表示根结点,sum[i-1]表示i到根结点的和,那么sum[j-1] - sum[i]可以得到区间[j, i]的和.那 ...
- hdu 3047(扩展并查集)
Zjnu Stadium Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...
- HDU 2818 (矢量并查集)
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2818 题目大意:每次指定一块砖头,移动砖头所在堆到另一堆.查询指定砖头下面有几块砖头. 解题思路: ...
- hdu 1116 欧拉回路+并查集
http://acm.hdu.edu.cn/showproblem.php?pid=1116 给你一些英文单词,判断所有单词能不能连成一串,类似成语接龙的意思.但是如果有多个重复的单词时,也必须满足这 ...
- Bipartite Graph hdu 5313 bitset 并查集 二分图
题目:http://acm.hdu.edu.cn/showproblem.php?pid=5313 题意: 给出n个顶点,m条边,问最多添加多少条边使之构成一个完全二分图 存储结构: bitset ...
- hdu 3081(二分+并查集+最大流||二分图匹配)
Marriage Match II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- 2015 ACM/ICPC Asia Regional Changchun Online HDU - 5441 (离线+并查集)
题目:http://acm.hdu.edu.cn/showproblem.php?pid=5441 题意:给你n,m,k,代表n个城市,m条边,k次查询,每次查询输入一个x,然后让你一个城市对(u,v ...
- hdu 3536【并查集】
hdu 3536 题意: 有N个珠子,第i个珠子初始放在第i个城市.有两种操作: T A B:把A珠子所在城市的所有珠子放到B城市. Q A:输出A珠子所在城市编号,该城市有多少个珠子,该珠子转移了 ...
- HDU 1829 分组并查集
题意:有两种性别,每组数据表示是男女朋友,判断输入的几组数据是否有同性恋 思路:http://blog.csdn.net/iaccepted/article/details/24304087 分组并查 ...
随机推荐
- 【适配整理】Android 7.0 调取系统相机崩溃解决android.os.FileUriExposedException
一.写在前面 最近由于廖子尧忙于自己公司的事情和 OkGo (一款专注于让网络请求更简单的网络框架) ,故让LZ 接替维护 ImagePicker(一款支持单.多选.旋转和裁剪的图片选择器),也是处理 ...
- 【react】使用 create-react-app 构建基于TypeScript的React前端架构----上
写在前面 一直在探寻,那优雅的美:一直在探寻,那精湛的技巧:一直在探寻,那简单又直白,优雅而美丽的代码. ------ 但是在JavaScript的动态类型.有时尴尬的自动类型转换,以及 “0 == ...
- JQuery_自带的动画效果
1.方法: show:显示选中元素. hide:隐藏选中元素. toggle:显示或隐藏选中元素. fadeIn:将选中元素的不透明度逐步提升到100%. fadeOut:将选中元素的不透明度逐步降为 ...
- WordPress更新时提示无法连接到FTP服务器的解决方案
这几天在搭建主站的时候,更新wordpress时无法连接到FTP原因服务器 解决方法如下: 在WordPress目录下找到wp-config.php文件并编辑,在最后一行加上: define('FS_ ...
- OC与JS的交互(iOS与H5混编)
大神总结WKWebView的坑:https://mp.weixin.qq.com/s/rhYKLIbXOsUJC_n6dt9UfA 在开发过程中,经常会出现需要iOS移动端与H5混编的使用场景. iO ...
- 置换群 Burnside引理 Pólya定理(Polya)
置换群 设\(N\)表示组合方案集合.如用两种颜色染四个格子,则\(N=\{\{0,0,0,0\},\{0,0,0,1\},\{0,0,1,0\},...,\{1,1,1,1\}\}\),\(|N|= ...
- 团队作业Week14——源代码管理
0. 在吹牛之前,先回答这个问题: 如果你的团队来了一个新队员,有一台全新的机器, 你们是否有一个文档,只要设置了相应的权限,她就可以根据文档,从头开始搭建环境,并成功地把最新.最稳定版本的软件编译出 ...
- linux第四次读书笔记
第四章:进程调度 一.多任务 1.非抢占式多任务 进程会一直执行直到自己主动停止运行(这一步骤称为让步) 2.抢占式多任务 Linux/Unix使用的是抢占式的方式:强制的挂起进程的动作就叫做抢占.进 ...
- Linux内核分析 读书笔记 (第七章)
第七章 链接 1.链接是将各种代码和数据部分收集起来并组合成为一个单一文件的过程,这个文件可被加载(或被拷贝)到存储器并执行. 2.链接可以执行于编译时,也就是在源代码被翻译成机器代码时:也可以执行于 ...
- Zookeeper 3.4.8分布式安装
1.机器信息 五台centos 64位机器 2.集群规划 Server Name Hadoop Cluster Zookeeper Ensemble HBase Cluster Hadoop01 ...