hdu 3038 How Many Answers Are Wrong

简介: 点击打开链接hdu 3038 思路: 带权并查集 分析: 1 给定一序列的区间的和,求错误的个数 2 典型的带权并查集,区间[l,r]的和等于sum[r]-sum[l-1]。

点击打开链接hdu 3038


思路: 带权并查集
分析:
1 给定一序列的区间的和,求错误的个数
2 典型的带权并查集,区间[l,r]的和等于sum[r]-sum[l-1]。对于一般涉及到区间和还有个数的问题的时候,都要把左下标减一来处理
3 用rank[x]表示的是x到跟节点的和即[x,find(x)]的和,那么对于给定的x,y,val,fx为x的跟节点,fy为y的跟节点
如果fx != fy那么这个时候就要考虑fx和fy的关系
fx > fy ,则father[fy] = fx; rank[fy] = rank[x]-val-rank[y];
fx < fy ,father[fx] = fy; rank[fx] = rank[y]+val-rank[x];
否则判断rank[x]-rank[y]是否为val

代码:

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;

const int MAXN = 200010;

int father[MAXN];
int rank[MAXN];

void init(int n){
    memset(rank , 0 , sizeof(rank));
    for(int i = 0 ; i <= n ; i++)
        father[i] = i;
}

int find(int x){
    if(father[x] != x){
       int fa = father[x];
       father[x] = find(fa);
       rank[x] += rank[fa];
    }
    return father[x];
}

bool solve(int x , int y , int val){
    int fx = find(x);
    int fy = find(y);
    if(fx != fy){
        if(fx > fy){
            father[fy] = fx;
            rank[fy] = rank[x]-val-rank[y];
        }
        else{
            father[fx] = fy;
            rank[fx] = rank[y]+val-rank[x];
        }
    }
    else{
        return rank[x]-rank[y] == val;
    }
    return true;
}

int main(){
    int n , m , ans;
    int x , y , val;
    while(scanf("%d%d" , &n , &m) != EOF){
         init(n);
         ans = 0;
         while(m--){
              scanf("%d%d%d" , &x , &y , &val);
              if(!solve(x-1 , y , val))
                  ans++;
         }
         printf("%d\n" , ans);
    }
    return 0;
}




目录
相关文章
|
前端开发 Java Maven
【注解使用】使用@JsonFormat注解踩过的坑
【注解使用】使用@JsonFormat注解踩过的坑
145 0
|
SQL 存储 Oracle
CBO中基数(cardinality)、可选择率(selectivity)的计算公式
CBO中基数(cardinality)、可选择率(selectivity)的计算公式 Cardinality(基数)是Oracle预估的返回行数,即对目标SQL的某个具体执行步骤的执行结果所包含记录数的估算值。
3086 0
|
传感器 数据采集 监控
实时数仓的特点
实时数仓的特点
219 0
|
Android开发
Android:解决TextView排版混乱问题
Android:解决TextView排版混乱问题
598 0
|
存储 NoSQL Ubuntu
Ubuntu 安装 MongoDB
Ubuntu 安装 MongoDB
967 0
|
存储 弹性计算 移动开发
无影云电脑桌面如何创建和使用?
无影云电脑桌面如何创建和使用?阿里云无影云桌面即无影云电脑,云电脑如何使用?云电脑购买后没有用户名和密码,先创建用户设置密码,才可以登录连接到云电脑。云电脑想要访问公网还需要开通互联网访问功能。阿里云百科来详细说下阿里云无影云电脑从购买、创建用户名密码和访问互联网全过程
494 0
|
SQL Web App开发 Oracle
Ichunqiu云境 —— Endless(无间计划) Writeup
两个入口点,一个入口点是pboot-cms,另外一个是SQL注入
|
IDE Java 程序员
C++开发环境最佳实践
C++开发环境最佳实践
604 0
C++开发环境最佳实践
|
SQL 缓存 算法
【MySQL】主从复制(重点:主从复制原理)
本文重点介绍MySQL的主从复制概述,作用,原理,同步数据一致性问题。
205 0

热门文章

最新文章