题目背景

Samcompu拥有大量的"水"资源!!

题目描述

Samcompu需要制定一个水计划。这个计划的主要目的就是为了避开老师监视的时间来水。

老师在中途会离开机房T次,第i次将会离开tim_i秒。Samcompu划水的时候可不是随便乱水的。他可是拥有"水"资源的。在他的库存中有N个可以水的网站。Samcompu拥有一种黑科技,他可以几乎不耗任何时间在网站与网站之间跳转并且把跳转的网页的信息秒存。也就是说,Samcompu并不需要在每一次跳转的时候花费时间去浏览网页。当然,这只局限于N个网站之间的N-1个跳转方式(保证每一个网站都可以跳转到另外的所有网站)。对于第i种跳转方式,第u_i个网站到第v_i个网站的跳转存在一个危险程度w_i,这个危险值可能会造成电脑卡死,如果Samcompu不能及时处理,那么就会完美地被老师发现。

值得一提的是,在被查水表很多次后,Samcompu总结出了一个规律:

老师走得越久,能够保证在被老师发现之前处理好电脑卡死的危险程度的上限就越高。简单来说,两者就是成正比的关系,比例系数为1。

可惜的是,Samcompu的黑科技并不稳定,在老师第i次离开的时候,第K_i个跳转方式就不可用了。

当然,每一次水都可以从任意一个网站开始,也可以从任意一个网站结束。

现在Samcompu想知道,对于第i次老师离开机房时,他能够有多少种不同的安全的水的方案。两种水的方案不同当且仅当这两种水的方案的第一个网站或者最后一个网站不同。

(补充说明: 一个安全的水的方案当且仅当当前是老师第j次离开教室时跳转的路径中不存在一个跳转方式i使得timj​⩽wi​,每一次水完后不可用的跳转方式就会恢复。)

输入输出格式

输入格式:

第一行两个正整数T, N

接下来N−1行,每一行三个正整数u_i, v_i​, w_i

接下来T行,每一行两个正整数m_i, K_i

输出格式:

T行,每行一个正整数表示有多少中安全的水的方案。

输入输出样例

输入样例#1:

3 5
1 2 1
1 3 2
3 4 1
3 5 3
1 1
2 2
3 3
输出样例#1:

0
4
6

说明

第一次连接1和2的边不可用,当前能经过的边的危险程度需要<1,并没有合法的方案。

第二次连接1和3的边不可用,当前能经过的边的危险程度需要<2,合法的方案有 (1,2) (2,1) (3,4) (4,3) 共四种。

第三次连接3和4的边不可用,当前能经过的边的危险程度需要<3,合法的方案有 (1,2) (1,3) (2,1) (2,3) (3,1) (3,2) 共六种。

提醒:本题计算答案按照点对的方式计算.也就是说,如果起点和终点一样,则只看做同一种方案.特别的,(x,y)(x,y)和(y,x)(y,x) (x≠y)算作两种不同的方案.

数据范围:

Subtask 1(30 pts):

1⩽Ki​⩽N⩽10^3 1⩽timi​,wi​⩽103

Subtask 2(50 pts):

1⩽T⩽5∗10^3 1⩽Ki​⩽N⩽10^4 1⩽timi​,wi​⩽10^3

Subtask 3(20 pts):

1⩽T⩽10^4 1⩽Ki​⩽N⩽10^4 1⩽timi​,wi​⩽10^3

数据保证不同的K_iKi​最多只有10^3个。

温馨提醒:由于出题人数据比较毒瘤,所以请尽量卡常。

分析:

我只想说出题人真的考虑了我的语文水平了吗。。。

事实上本题就是按并查集的方式加边,然后再在合并的时候进行计算。

至于失效直接保存即可。

CODE:

 #include <cstdio>
#include <cstring>
#include <cmath>
#include <iostream>
#include <algorithm>
using namespace std;
const int M=;
int t,n,tot,ans[M],fa[M],now[M],sl[M],last;
int fr(){
char c=getchar();int ans=;
while (c<''||c>'') c=getchar();
while (c>=''&&c<='') ans=(ans<<)+(ans<<)+(c^),c=getchar();
return ans;
}
int found(int x){
if (fa[x]==x) return x;
return fa[x]=found(fa[x]);
}
struct node{
int tim,K,num;
}ask[M];
struct node2{
int from,to,adj,num;
}e[M];
bool cmp(node x,node y){
if (x.K==y.K) return x.tim<y.tim;
return x.K<y.K;
}
bool cmp2(node2 x,node2 y){
return x.adj<y.adj;
}
void add(int u,int v,int w,int id){
e[++tot].from=u;e[tot].to=v;
e[tot].adj=w;e[tot].num=id;
return;
}
int count(int x){
return x*(x-);
}
int main(){
t=fr(),n=fr();
for (int i=;i<n;i++){
int u=fr(),v=fr(),w=fr();
add(u,v,w,i);
}
for (int i=;i<=t;i++) ask[i].tim=fr(),ask[i].K=fr(),ask[i].num=i;
sort(ask+,ask++t,cmp);
sort(e+,e+n,cmp2);
for (int i=;i<n;i++) now[e[i].num]=i;
for (int i=;i<=t;i++){
if (i==||ask[i].K!=ask[i-].K){
for (register int j=;j<=n;j++) fa[j]=j,sl[j]=;
last=;ans[ask[i].num]=;
}
else ans[ask[i].num]=ans[ask[i-].num];
while (last<n&&e[last].adj<ask[i].tim){
if (last!=now[ask[i].K]&&found(e[last].from)!=found(e[last].to)){
int now1=found(e[last].from),now2=found(e[last].to);
ans[ask[i].num]+=count(sl[now1]+sl[now2])-count(sl[now1])-count(sl[now2]);
sl[now2]+=sl[now1];sl[now1]=;
fa[now1]=now2;
}
last++;
}
}
for (int i=;i<=t;i++) printf("%d\n",ans[i]);
return ;
}

Samcompu Loves Water的更多相关文章

  1. 【洛谷】CYJian的水题大赛【第二弹】解题报告

    点此进入比赛 T1: JerryC Loves Driving 第一题应该就是一道水分题(然而我只水了130分),我的主要做法就是暴力模拟,再做一些小小的优化(蠢得我自己都不想说了). My Code ...

  2. CYJian的水题大赛2 解题报告

    这场比赛是前几天洛谷上 暮雪﹃紛紛dalao的个人公开赛,当时基本上都在水暴力分......也没有好好写正解(可能除了T1) 过了几天颓废的日子之后,本蒟蒻觉得应该卓越一下了qwq,所以就打算写一个解 ...

  3. Microsoft Loves Linux

    微软新任CEO纳德拉提出的“Microsoft Loves Linux”,并且微软宣布.NET框架的开源,近期Microsoft不但宣布了Linux平台的SQL Server,还宣布了Microsof ...

  4. [LeetCode] Pacific Atlantic Water Flow 太平洋大西洋水流

    Given an m x n matrix of non-negative integers representing the height of each unit cell in a contin ...

  5. [LeetCode] Trapping Rain Water II 收集雨水之二

    Given an m x n matrix of positive integers representing the height of each unit cell in a 2D elevati ...

  6. [LeetCode] Water and Jug Problem 水罐问题

    You are given two jugs with capacities x and y litres. There is an infinite amount of water supply a ...

  7. [LeetCode] Trapping Rain Water 收集雨水

    Given n non-negative integers representing an elevation map where the width of each bar is 1, comput ...

  8. [LeetCode] Container With Most Water 装最多水的容器

    Given n non-negative integers a1, a2, ..., an, where each represents a point at coordinate (i, ai). ...

  9. 如何装最多的水? — leetcode 11. Container With Most Water

    炎炎夏日,还是呆在空调房里切切题吧. Container With Most Water,题意其实有点噱头,简化下就是,给一个数组,恩,就叫 height 吧,从中任选两项 i 和 j(i <= ...

随机推荐

  1. 数学&计算机工程常用希腊字母表及其发音

  2. Java输入/输出教程

    Java输入/输出(I/O)处理从源读取数据并将数据写入目标.通常,读取存储在文件中的数据或使用I/O将数据写入到文件中. java.io和java.nio包中包含处理输入/输出的Java类.java ...

  3. UVA_548Tree

    这是一个很经典的建树,然而当时不会!!!! 给你一个中序和后序 先建一个二叉树,然后找最优解(最优解就是一个叶子节点到根节点权值最小, 同时本身权值最小) //生成一棵树 int build(int ...

  4. 分布式ID生成器的解决方案总结

    在互联网的业务系统中,涉及到各种各样的ID,如在支付系统中就会有支付ID.退款ID等.那一般生成ID都有哪些解决方案呢?特别是在复杂的分布式系统业务场景中,我们应该采用哪种适合自己的解决方案是十分重要 ...

  5. C语言中各种进制的表示

    #include<stdio.h> int main() { //默认情况下是十进制 ; // 二进制(0b或者0B开头) int number2 = 0b1100; //八进制(0开头) ...

  6. 聊聊动态链接和dl_runtime_resolve

    写在前面 linux下的动态链接相关结构,重新回顾_dl_runtime_resolve的流程以及利用方法 动态链接相关结构 为了高效率的利用内存,多个进程可以共享代码段.程序模块化方便更新维护等,动 ...

  7. C3P0连接池属性配置注释

    属性 解释 acquireIncrement 当连接池中的连接耗尽的时候c3p0一次同时获取的连接数 默认为:3 acquireRetryAttempts 定义在从数据库获取新连接失败后重复尝试的次数 ...

  8. redux 基础

    antd 的使用 1.安装npm install antd --save 2.引入到项目中 import 'antd/dist/antd.css'; // or 'antd/dist/antd.les ...

  9. Java中的LinkedHashSet

  10. jsp引擎是什么

    1.JSP引擎 执行JSP代码需要在服务器上安装JSP引擎,比较常见的引擎有webLogic和Tomcat.把这些支持JSP的web服务器配置好后,就可以在客户端通过浏览器来访问JSP页面了. 2.J ...