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;
}




目录
相关文章
|
iOS开发
动态的Objective-C——关于消息机制与运行时的探讨(三)
动态的Objective-C——关于消息机制与运行时的探讨
291 0
动态的Objective-C——关于消息机制与运行时的探讨(三)
读《马云:贪婪和拜金主义让我感到担忧》有感
    马云答记者问,《马云:贪婪和拜金主义让我感到担忧》,原文请点击:http://business.sohu.com/20120127/n333003816.shtml      其中:     1、查理罗斯:你认为你们的核心竞争力是什么?   马云:不是科技,而是文化!科技只是工具,我们更重视价值、使命和愿景。
1017 0
|
22小时前
|
云安全 人工智能 安全
AI被攻击怎么办?
阿里云提供 AI 全栈安全能力,其中对网络攻击的主动识别、智能阻断与快速响应构成其核心防线,依托原生安全防护为客户筑牢免疫屏障。
|
10天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
4天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
429 191
|
3天前
|
数据采集 消息中间件 人工智能
跨系统数据搬运的全方位解析,包括定义、痛点、技术、方法及智能体解决方案
跨系统数据搬运打通企业数据孤岛,实现CRM、ERP等系统高效互通。伴随数字化转型,全球市场规模超150亿美元,中国年增速达30%。本文详解其定义、痛点、技术原理、主流方法及智能体新范式,结合实在Agent等案例,揭示从数据割裂到智能流通的实践路径,助力企业降本增效,释放数据价值。
|
8天前
|
人工智能 自然语言处理 安全
国内主流Agent工具功能全维度对比:从技术内核到场景落地,一篇读懂所有选择
2024年全球AI Agent市场规模达52.9亿美元,预计2030年将增长至471亿美元,亚太地区增速领先。国内Agent工具呈现“百花齐放”格局,涵盖政务、金融、电商等多场景。本文深入解析实在智能实在Agent等主流产品,在技术架构、任务规划、多模态交互、工具集成等方面进行全维度对比,结合市场反馈与行业趋势,为企业及个人用户提供科学选型指南,助力高效落地AI智能体应用。