HDU 3038 How Many Answers Are Wrong(带权并查集)
太坑人了啊,读入数据a,b,s的时候,我刚开始s用的%lld,给我WA。 实在找不到错误啊,后来不知怎么地突然有个想法,改成%I64d,竟然AC了
思路:我建立一个sum数组,设i的父亲为fa,sum[i]表示(fa,i]中的数的和(不包括fa,包括i),
合并的时候,不是合并a,b,而是合并a-1,b。这样做的目是因为s是[a,b]的和,如果直接合并a,b,那么按照我数组的定义应该是(a,b]的和,这样不符合题意。
接下来,每次读入a,b,只要根据他们父节点的不同情况分类讨论即可。
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std; const int maxn=;
int father[maxn];
long long sum[maxn]; //设i的父亲为fa,sum[i]表示(fa,i]中的数的和(不包括fa,包括i)
int n,m;
void init() {
for(int i=; i<=n; i++) {
father[i]=i;
sum[i]=;
}
} int find_root(int x) {
if(father[x]==x)
return x;
int fa=father[x];
father[x]=find_root(father[x]);
sum[x]=(sum[x]+sum[fa]);
return father[x];
}
//合并的时候,保证x<y
void Union(int x,int y) {
father[y]=x;
}
int main() {
int a,b,ans=;
long long s;
while(scanf("%d%d",&n,&m)!=EOF) {
init(); //怎么老忘记写这个啊
ans=;
for(int i=; i<=m; i++) {
scanf("%d%d%I64d",&a,&b,&s); //就是这里,本来用的是lld的格式,导致WA
int fa=find_root(a-);
int fb=find_root(b);
/*
fa=fb时,(fa,a-1]=sum[a-1],(fb,b]=sum[b],
——>[a,b]=sum[b]-sum[a-1],显然即应该等于s
若不等于,即使错误的
*/
if(fa==fb) {
if(sum[b]-sum[a-]!=s) {
ans++;
}
}
else {
if(fb>a-) {
/*
大小关系:fa<=a-1<fb<=b
(fa,a-1]=sum[a-1],[a,b]=s,(fb,b]=sum[b];
——>[a,fb]=s-sum[b],
(fa,fb]=(fa,a-1]+[a-1,fb]=sum[a-1]+s-sum[b];
*/
Union(fa,fb);
//更新fb的父节点fa到fb区间的和(不包括fa)
sum[fb]=sum[a-]+s-sum[b];
} else if(fb==a-) {
/*
大小关系:fa<=a-1=fb<=b
(fa,a-1]=sum[a-1],[a,b]=s,(fb,b]=sum[b];
——>sum[b]即为[a,b]的和。
若sum[b]不等于s,说明错误
如果相同,则合并
*/
if(s!=sum[b]) {
ans++;
} else {
Union(fa,fb);
sum[fb]=sum[a-];
}
}
//fb<a-1
else {
if(fb>fa) {
/*
大小关系:fa<fb<a-1<b
(fb,b]=sum[b],(a-1,b]=s ——>(fb,a-1]=sum[b]-s;
再由(fa,a-1]=sum[a-1]——>(fa,fb]=sum[a-1]-sum[b]+s;
*/
Union(fa,fb);
sum[fb]=sum[a-]-sum[b]+s;
}
else {
/*
大小关系:fb<fa<=a-1<=b
(fb,b]=sum[b],(a-1,b]=s,(fa,a-1]=sum[a-1];
——>(fa,b]=s+sum[a-1]
——>(fb,fa]=sum[b]-s-sum[a-1];
*/
Union(fb,fa);
sum[fa]=sum[b]-s-sum[a-];
} }
}
}
printf("%d\n",ans);
}
return ;
}
HDU 3038 How Many Answers Are Wrong(带权并查集)的更多相关文章
- hdu 3038 How Many Answers Are Wrong ( 带 权 并 查 集 )
How Many Answers Are Wrong Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- HDU3038 How Many Answers Are Wrong —— 带权并查集
题目链接:http://acm.split.hdu.edu.cn/showproblem.php?pid=3038 How Many Answers Are Wrong Time Limit: 200 ...
- hdu3038How Many Answers Are Wrong(带权并查集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3038 题解转载自:https://www.cnblogs.com/liyinggang/p/53270 ...
- HDU 1829 A Bug's Life 【带权并查集/补集法/向量法】
Background Professor Hopper is researching the sexual behavior of a rare species of bugs. He assumes ...
- HDU3038 How Many Answers Are Wrong[带权并查集]
How Many Answers Are Wrong Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
- 【HDU3038】How Many Answers Are Wrong - 带权并查集
描述 TT and FF are ... friends. Uh... very very good friends -________-b FF is a bad boy, he is always ...
- hdu 3038 How Many Answers Are Wrong(种类并查集)2009 Multi-University Training Contest 13
了解了种类并查集,同时还知道了一个小技巧,这道题就比较容易了. 其实这是我碰到的第一道种类并查集,实在不会,只好看着别人的代码写.最后半懂不懂的写完了.然后又和别人的代码进行比较,还是不懂,但还是交了 ...
- How Many Answers Are Wrong(带权并查集)
How Many Answers Are Wrong http://acm.hdu.edu.cn/showproblem.php?pid=3038 Time Limit: 2000/1000 MS ( ...
- HDU3038:How Many Answers Are Wrong(带权并查集)
How Many Answers Are Wrong Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Ja ...
随机推荐
- struts2中访问servlet API
Struts2中的Action没有与任何Servlet API耦合,,但对于WEB应用的控制器而言,不访问Servlet API几乎是不可能的,例如需要跟踪HTTP Session状态等.Struts ...
- Linux下mysql的安装和使用(C语言)
1 mysql的安装 我使用的ubuntu在线安装,非常简单,命令为: sudo apt-get install mysql-client mysql-server 2 mysql命令集合 网络太多了 ...
- JAVA多线程学习--生产者消费者问题
一.问题描述 生产者消费者问题是一个典型的线程同步问题.生产者生产商品放到容器中,容器有一定的容量(只能顺序放,先放后拿),消费者消费商品,当容器满了后,生产者等待,当容器为空时,消费者等待.当生产者 ...
- JS 获取select(多选下拉)中所选值的示例代码
通过js获取select(多选下拉)中所选值,具体实现如下,有需要的朋友可以参考下,希望对大家有所帮助 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML ...
- PHP实现根据浏览器跳转不同语言页面代码
以下是对使用PHP实现根据浏览器跳转不同语言页面的代码进行了介绍,需要的朋友可以过来参考下 代码: <?php /** * 根据不同浏览器跳转不同页面 * 来源:www.jbxue.com * ...
- 用“逐步排除”的方法定位Java服务线上“系统性”故障(转)
一.摘要 由于硬件问题.系统资源紧缺或者程序本身的BUG,Java服务在线上不可避免地会出现一些“系统性”故障,比如:服务性能明显下降.部分(或所 有)接口超时或卡死等.其中部分故障隐藏颇深,对运维和 ...
- CPU 时间片 分时 轮转调度
时间片即CPU分配给各个程序的时间,每个线程被分配一个时间段,称作它的时间片,即该进程允许运行的时间,使各个程序从表面上看是同时进行的.如果在时间片结束时进程还在运行,则CPU将被剥夺并分配给另一个进 ...
- 【css老版本浏览器兼容利器】ie-css3.htc
做前端的同学都应该听说或者用过,是一段脚本,可以让ie实现css3里的圆角和阴影效果. css带来的便利是很容易感受的到的,但恶心的是它在ie下的不兼容,所以某位牛人现身写了个ie-css3.htc, ...
- 从零开始学ios开发(五):IOS控件(2),Slider
下面继续学习ios的其他控件,这次会使用到的控件有Slider,当然还有一些之前已经使用过的控件Label. 这次我们不新建一个project了,当然如果你愿意重新创建一个新的项目也完全可以,我们还是 ...
- 【h5-egret】深入浅出对象池
最近看到对象池这一块的东西,是频繁创建和删除类型游戏优化性能的一个解决方案. 简单来讲对象池就是个数组,把不用的对象放进去,因为数组还保存了对象的引用,所以对象不会被回收,等需要用的时候再从数组中取出 ...