la4730

初看此题还真心没有碰到过这样的类型,还以为是计算机和。但是居然是线段树。。。。

额额额 。。。

此题精妙之处在于用线段树维护Y轴的坐标。同时用并查集维护每个州。那么并查集的个数就是州的个数,然后并查集中元素的个数就是城市的个数。

那么当我一个线段扫过去,所到的并查集那么就统计下来,然后加上其中的个数。

这里还要一个处理的地方,那就是y值可能是小数,但是题中也说了保证是0.5的实数。所以我将y值扩大2倍那么就保证了所有的y值都为整数了。

对于每一个并查集我记录他的父亲,记录y的最小值和最大值还有并查集中的城市个数。

那么当我添加一条road,那么当前点就并到一起去,那么对于当前并查集中就将两个数的  增量  记得是增量哦 就是这个问题搞得我debug好久 增加到线段树中去  记得此处增量要考虑下两个地方,即假设ab两点相连,那么a和b的城市数目其实很说,只要城市数目的增量相加就好了。但是此处的州数的增量要注意。我就是一直卡这卡好久(我一开始是将b的州数-1,b的城市数减去,然后将a的州数不减,a的城市数+b的城市数但是不知道怎么一直报wa,然后我就索性两个都把州数减了,然后在在后面a的州数+1不知怎么又过了)。然后query的时候就很方便了,只要将传过去的州数和城市数统计起来就好了


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值