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中constant参数设置
序号 方法 说明 1 <constant name="struts.i18n.encoding" value="UTF-8"/> 指定web应用默认 ...
- 《linux 网卡别名的添加和绑定》RHEL6
网卡别名的配置: 这个和ifconfig临时修改网卡ip 差不多,但是不一样.都是临时的,只要重启电脑就没了. 配永久的ip别名: cp ifcfg-eth0 ifcfg-eth0:0 vim if ...
- Centos6.4版本下搭建LAMP环境
Centos6.4版本下搭建LAMP环境 配置yum mkdir/mnt/cdrom mount/dev/cdrom /mnt/cdrom 装载光盘 vi /etc/yum.repos.d/Cent ...
- 【转】IL编织 借助PostSharp程序集实现AOP
ref: C# AOP实现方法拦截器 在写程序的时候,很多方法都加了.日志信息.比如打印方法开始,方法结束,错误信息,等等. 由于辅助性功能的代码几乎是完全相同的,这样就会令同样的代码在各个函数中 ...
- flex基础学习
Flex是Adobe开发的一种RIA,富互联网应用,用Flex开发的东西都可以使用Flash做出来,但是Flex主要是面向的程序开发人员,前台使用ActionScript和MXML. 上面介绍了fle ...
- 【Qt】Qt之进程间通信(共享内存)【转】
简述 上一节中,我们分享下如何利用Windows消息机制来进行不同进程间的通信.但是有很多局限性,比如:不能跨平台,而且必须两个进程同时存在才可以,要么进程A发了消息谁接收呢? 下面我们来分享另外一种 ...
- php实现input输入框失去焦点自动保存输入框的数据
最近做一个输入框失去焦点时自动保存数据的功能,当然就是jQuery选择器选择input,blur时,ajax提交数据给php文件,php文件保存一下数据咯.主要是要注意一下中文的问题,所以中间需要转一 ...
- python的各种推导式(列表推导式、字典推导式、集合推导式)
推导式comprehensions(又称解析式),是Python的一种独有特性.推导式是可以从一个数据序列构建另一个新的数据序列的结构体. 共有三种推导,在Python2和3中都有支持: 列表(lis ...
- 【iOS】Objective-C简约而不简单的单例模式
前些日子在项目中因为误用了单例而导致了一系列问题.原来在objective-c中的单例并没有java或者C#那么简单的实现,这里记录下: 问题是这样被发现的,在对于一个UIViewController ...
- range,shuffle,str_shuffle
print_r(range(1,20)); 输出,range产生 Array( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 ...