调了一个下午只有八十分QAQ md弃了不管了 对拍也没拍出来 鬼知道是什么数据把我卡了QAQ

没事我只是个SB而已 这题其实还是蛮正常的

做法其实很简单 根据链剖的构造方法 你每次修改都是一段又一段的线段

那么你只要求一下线段并起来后哪些地方被覆盖了>=t次 不过要基数排序一波不然会T

#include<cstdio>
#include<cstring>
#include<algorithm>
#define LL long long
using std::swap;
using std::max;
const int N=,M=,B=;
int read(){
int ans=,f=,c=getchar();
while(c<''||c>''){if(c=='-') f=-; c=getchar();}
while(c>=''&&c<=''){ans=ans*+(c-''); c=getchar();}
return ans*f;
}
int n,m;
int first[N],cnt=;
struct node{int to,next;}e[*N];
void ins(int a,int b){e[++cnt]=(node){b,first[a]}; first[a]=cnt;}
void insert(int a,int b){ins(a,b); ins(b,a);}
int dep[N],top[N],sz[N],son[N],mx[N],fa[N],id[N],idp=;
void f1(int x){
sz[x]=;
for(int i=first[x];i;i=e[i].next){
int now=e[i].to;
if(now==fa[x]) continue;
fa[now]=x; dep[now]=dep[x]+;
f1(now);sz[x]+=sz[now];
if(sz[now]>sz[son[x]]) son[x]=now;
}
}
void f2(int x,int tp){
top[x]=tp; mx[x]=id[x]=idp++;
if(son[x]) f2(son[x],tp),mx[x]=max(mx[x],mx[son[x]]);
for(int i=first[x];i;i=e[i].next){
int now=e[i].to;
if(now!=fa[x]&&now!=son[x]) f2(now,now),mx[x]=max(mx[x],mx[now]);
}
}
bool ly;
int a,b,t,cntq;
int f[*M];
struct pos{int r,id,s;}q[M];
bool cmp(pos a,pos b){return a.r<b.r;}
void pcalc(){
memset(f,,sizeof(f));
for(int i=;i<cntq;i++) f[q[i].r]+=q[i].s;
cntq=;
}
void modify(int x,int y,int k){
while(top[x]!=top[y]){
if(dep[top[x]]<dep[top[y]]) swap(x,y);
if(!ly){f[id[top[x]]]++; f[id[x]+]--; x=fa[top[x]];continue;}
q[cntq++]=(pos){id[top[x]],k,};
q[cntq++]=(pos){id[x]+,k,-};
if(cntq>1e6&&ly){pcalc(); ly=false;}
x=fa[top[x]];
}
if(id[x]>id[y]) swap(x,y);
if(!ly){f[id[x]]++; f[id[y]+]--; return ;}
q[cntq++]=(pos){id[x],k,};
q[cntq++]=(pos){id[y]+,k,-};
}
int T[];
pos *s[],*mp;
pos bb[M];
void jsort(int n){
memset(T,,sizeof(T)); mp=bb;
for(int i=;i<n;i++) ++T[q[i].r&];
for(int i=;i<B;i++) s[i]=mp,mp+=T[i];
for(int i=;i<n;i++) *s[q[i].r&]++=q[i];
memset(T,,sizeof(T)); mp=q;
for(int i=;i<n;i++) ++T[bb[i].r>>];
for(int i=;i<B;i++) s[i]=mp,mp+=T[i];
for(int i=;i<n;i++) *s[bb[i].r>>]++=bb[i];
}
int main(){
//freopen("gg.in","r",stdin);
int x,y;
n=read(); m=read();
for(int i=;i<n;i++) x=read(),y=read(),insert(x,y);
f1(); f2(,);
for(int i=;i<=m;i++){
a=read(); b=read(); t=read();
cntq=;
ly=true;
for(int j=;j<=a;j++){
x=read(); y=read();
modify(x,y,i);
}
for(int j=;j<=b;j++){
x=read();
if(!ly){f[id[x]]++; f[mx[x]+]--;continue;}
q[cntq++]=(pos){id[x],i,};
q[cntq++]=(pos){mx[x]+,i,-};
if(cntq>1e6&&ly){pcalc(); ly=false;}
}
if(t==){printf("%d\n",n); continue;}
if(ly){
jsort(cntq);
int now=,ans=;
for(int j=;j<cntq;j++){
now+=q[j].s;
if(j!=cntq-&&now>=t) ans=ans+q[j+].r-q[j].r;
}
if(now>=t) ans=ans+n-q[cntq-].r+;
printf("%d\n",ans);
}
else{
int now=,ans=;
for(int j=;j<=n;j++){
now+=f[j];
if(now>=t) ans++;
}printf("%d\n",ans);
}
}
return ;
}

洛谷金秋夏令营模拟赛 第2场 T11738 伪神的更多相关文章

  1. 洛谷金秋夏令营模拟赛 第2场 T11737 时之终末

    这道题就是道状压dp...比赛的时候太贪心 然后状压又不好 所以T2 T3一起挂了QAQ 吸取教训QAQ f[i][j][k]表示前i个数选了j个 最后a个的状态为k的答案 #include<c ...

  2. 洛谷 P5046 [Ynoi2019 模拟赛] Yuno loves sqrt technology I(分块+卡常)

    洛谷题面传送门 zszz,lxl 出的 DS 都是卡常题( 首先由于此题强制在线,因此考虑分块,我们那么待查询区间 \([l,r]\) 可以很自然地被分为三个部分: 左散块 中间的整块 右散块 那么这 ...

  3. 洛谷CON1041 NOIP模拟赛一试

    A T2-power of 2 题目描述 是一个十分特殊的式子. 例如: n=0时 =2 然而,太大了 所以,我们让对10007 取模 输入输出格式 输入格式: n 输出格式:  % 10007 输入 ...

  4. [洛谷P5048][Ynoi2019模拟赛]Yuno loves sqrt technology III

    题目大意:有$n(n\leqslant5\times10^5)$个数,$m(m\leqslant5\times10^5)$个询问,每个询问问区间$[l,r]$中众数的出现次数 题解:分块,设块大小为$ ...

  5. 【洛谷】xht模拟赛 题解

    前言 大家期待已久并没有的题解终于来啦~ 这次的T1和HAOI2016撞题了...深表歉意...表示自己真的不知情... 天下的水题总是水得相似,神题各有各的神法.--<安娜·卡列妮娜> ...

  6. 洛谷P5048 [Ynoi2019模拟赛]Yuno loves sqrt technology III(分块)

    传送门 众所周知lxl是个毒瘤,Ynoi道道都是神仙题 用蒲公英那个分块的方法做结果两天没卡过去→_→ 首先我们分块,预处理块与块之间的答案,然后每次询问的时候拆成整块和两边剩下的元素 整块的答案很简 ...

  7. [洛谷0925]NOIP模拟赛 个人公开赛 OI

     P3395 路障 题目背景 此题约为NOIP提高组Day1T1难度. 题目描述 B君站在一个n*n的棋盘上.最开始,B君站在(1,1)这个点,他要走到(n,n)这个点. B君每秒可以向上下左右的某个 ...

  8. 洛谷 P5048 - [Ynoi2019 模拟赛] Yuno loves sqrt technology III(分块)

    题面传送门 qwq 感觉跟很多年前做过的一道题思路差不多罢,结果我竟然没想起那道题?!!所以说我 wtcl/wq 首先将 \(a_i\) 离散化. 如果允许离线那显然一遍莫队就能解决,复杂度 \(n\ ...

  9. NOI.AC NOIP模拟赛 第五场 游记

    NOI.AC NOIP模拟赛 第五场 游记 count 题目大意: 长度为\(n+1(n\le10^5)\)的序列\(A\),其中的每个数都是不大于\(n\)的正整数,且\(n\)以内每个正整数至少出 ...

随机推荐

  1. 第一周—Fortran语言学习

    使用教材:Fortran95程序设计[彭国伦] 第二章 编译器的使用 编译结果的好坏 1.翻译正确 2.执行文件的运行效率 3.翻译出来的执行码的长短 4.编译过程花费的时间 5.编译器提供Debug ...

  2. String 和 CharSequence 关系与区别

    String 继承于CharSequence,也就是说String也是CharSequence类型. CharSequence是一个接口,它只包括length(), charAt(int index) ...

  3. React 16.x & Hooks

    React 16.x & Hooks Hooks https://reactjs.org/docs/hooks-intro.html https://reactjs.org/docs/hook ...

  4. 2.StringBuffer:线程安全的可变字符串序列

    一.String.StringBuffer和StringBuilder的区别 1.String是内容不可变的,而StringBuffer和StringBuilder都是内容可变的. 2.StringB ...

  5. prototype的本质

    在<关于思维方式的思绪>那篇文章里提到了, 原型的本质就是一种委托关系. 即我这里没有,就到我的原型里去看看,一旦找到就当成我的用. 本文详细说一下这个事情. 比如某女买东西,钱都是她老公 ...

  6. BZOJ4869 六省联考2017相逢是问候(线段树+欧拉函数)

    由扩展欧拉定理,a^(a^(a^(……^x)))%p中x作为指数的模数应该是φ(φ(φ(φ(……p)))),而p取log次φ就会变为1,也即每个位置一旦被修改一定次数后就会变为定值.线段树维护区间剩余 ...

  7. BZOJ 3040最短路

    题目描述 给定一个 NN 个点, MM 条有向边的带权图,请你计算从 SS 出发,到每个点的距离. 数据保证你能从 SS 出发到任意点. 输入输出格式 输入格式: 第一行两个整数 NN . MM ,表 ...

  8. 【刷题】UOJ #34 多项式乘法

    这是一道模板题. 给你两个多项式,请输出乘起来后的多项式. 输入格式 第一行两个整数 \(n\) 和 \(m\) ,分别表示两个多项式的次数. 第二行 \(n+1\) 个整数,表示第一个多项式的 \( ...

  9. BZOJ3236:[AHOI2013]作业——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=3236 第一种做法: 建两棵主席树分别处理两个问题. 第一个问题水,第二个问题参考SPOJ3267/ ...

  10. AOJ.859 地毯填补问题 (递归与分治)

    AOJ.859 地毯填补问题 (递归与分治) 题意分析 学习分治思想,第一次接触, 代码总览 #include <iostream> #include <cstdio> #in ...