Samcompu Loves Water
题目背景
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行,每行一个正整数表示有多少中安全的水的方案。
输入输出样例
3 5
1 2 1
1 3 2
3 4 1
3 5 3
1 1
2 2
3 3
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的更多相关文章
- 【洛谷】CYJian的水题大赛【第二弹】解题报告
点此进入比赛 T1: JerryC Loves Driving 第一题应该就是一道水分题(然而我只水了130分),我的主要做法就是暴力模拟,再做一些小小的优化(蠢得我自己都不想说了). My Code ...
- CYJian的水题大赛2 解题报告
这场比赛是前几天洛谷上 暮雪﹃紛紛dalao的个人公开赛,当时基本上都在水暴力分......也没有好好写正解(可能除了T1) 过了几天颓废的日子之后,本蒟蒻觉得应该卓越一下了qwq,所以就打算写一个解 ...
- Microsoft Loves Linux
微软新任CEO纳德拉提出的“Microsoft Loves Linux”,并且微软宣布.NET框架的开源,近期Microsoft不但宣布了Linux平台的SQL Server,还宣布了Microsof ...
- [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 ...
- [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 ...
- [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 ...
- [LeetCode] Trapping Rain Water 收集雨水
Given n non-negative integers representing an elevation map where the width of each bar is 1, comput ...
- [LeetCode] Container With Most Water 装最多水的容器
Given n non-negative integers a1, a2, ..., an, where each represents a point at coordinate (i, ai). ...
- 如何装最多的水? — leetcode 11. Container With Most Water
炎炎夏日,还是呆在空调房里切切题吧. Container With Most Water,题意其实有点噱头,简化下就是,给一个数组,恩,就叫 height 吧,从中任选两项 i 和 j(i <= ...
随机推荐
- Spring Cloud配置中心内容加密
从配置获取的配置默认是明文的,有些像数据源这样的配置需要加密的话,需要对配置中心进行加密处理. 下面使用对称性加密来加密配置,需要配置一个密钥,当然也可以使用RSA非对称性加密,但对称加密比较方便也够 ...
- python基础【第五篇】
python第三节 1.整型及布尔值 1.1 进制转换 十进制 ----二进制 二进制 ----十进制 8421方法与普通计算 python中十进制转二进制示例:bin(51)>>> ...
- python调用tushare获取沪深股通十大成交股
接口:hsgt_top10 描述:获取沪股通.深股通每日前十大成交详细数据 注:tushare库下载和初始化教程,请查阅我之前的文章 输入参数 名称 | 类型 | ...
- es+mongodb 整合
之前公司项目的数据都是从mysql查询,后面需求变更:同时技术上相应的也要改变策略,决定将mongodb和mysql的数据通过es建立索引来查询: 对于还没有接触或者真正了解es的可以先看一下相关Lu ...
- js canvas 粒子动画 电子表
前言 从我接触canvas的第一天就觉得canvas很有趣,想搞点事情,这几天终于忍不住了,于是他来了. 先看效果 这里我做了四个大家有兴趣可以看完文章, ...
- 总结下awk基本用法
命令格式: awk '{commands} [{other commands}]' awk 'condition{commands} [{other commands}]' 如:awk '$4==&q ...
- JavaScript常用技巧之数组操作
1.获取最后数组中最后一个元素 . arr.slice(-1).pop() . arr[arr.length - 1] 2.过滤重复元素 arr.filter(function(v, i) { ret ...
- 开启.NET Core 3时代,DevExpress v19.2.5带你全新启航
DevExpress Universal Subscription(又名DevExpress宇宙版或DXperience Universal Suite)是全球使用广泛的.NET用户界面控件套包,De ...
- jupyter|浏览器启动问题|“ImportError: DLL load failed: 找不到指定的模块”sqlite3
问题: 1.安装好Anconda3后,开始——>打开jupyter notebook时 默认浏览器无法启动 2.开始打开——>anaconda prompt 输入jupyter noteb ...
- open source library
{ https://gitee.com/tboox https://github.com/thejinchao/cyclone http://www.drchip.org/astronaut/ssl/ ...