結果
| 問題 |
No.1038 TreeAddQuery
|
| コンテスト | |
| ユーザー |
beet
|
| 提出日時 | 2020-03-02 20:49:08 |
| 言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 3,497 bytes |
| コンパイル時間 | 2,224 ms |
| コンパイル使用メモリ | 208,120 KB |
| 最終ジャッジ日時 | 2025-01-09 03:57:20 |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 5 TLE * 19 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
using Int = long long;
template<typename T1,typename T2> inline void chmin(T1 &a,T2 b){if(a>b) a=b;}
template<typename T1,typename T2> inline void chmax(T1 &a,T2 b){if(a<b) a=b;}
struct FastIO{
FastIO(){
cin.tie(0);
ios::sync_with_stdio(0);
}
}fastio_beet;
const int MAX = 1e5 + 10;
int P[MAX*2]={};
int D[MAX*2]={};
int E[MAX*2]={};
int A[MAX*2]={};
int B[MAX*2]={};
int ht[MAX*2]={};
int dat[20][MAX / 5] = {};
struct LCA{
const int lg = 12;
const int sz = 1<<lg;
const int ms = sz-1;
int n;
vector<int> T;
vector<vector<int>> G;
LCA(int n):
n(n),T(sz,0),G(n){
memset(P,-1,sizeof(P));
memset(A,-1,sizeof(A));
memset(dat,-1,sizeof(dat));
}
void add_edge(int u,int v){
G[u].emplace_back(v);
G[v].emplace_back(u);
}
void dfs(int v,int p,int d){
int k=0,u;
vector<int> iter(n,0);
using T = tuple<int, int, int>;
stack<T> st;
START:
D[v]=k;
A[k]=P[v]=p;
E[k++]=d;
for(;iter[v]<(int)G[v].size();iter[v]++){
u=G[v][iter[v]];
if(u==p) continue;
st.emplace(v,p,d);
p=v;v=u;d=d+1;
goto START;
END:
tie(v,p,d)=st.top();st.pop();
}
A[k]=P[v];
E[k++]=d-1;
if(!st.empty()) goto END;
}
// if it need leftmost, then add: if(E[i]==E[j]) return i<j?i:j;
inline int comp(int i,int j){return E[i]<E[j]?i:j;};
inline int comp(int i,int j,int k){return comp(comp(i,j),k);};
void build(int r=0){
dfs(r,-1,1);
B[0]=1;
for(int i=1;i<n*2;i++) B[i/lg]|=(E[i-1]<E[i])<<(i%lg);
for(int b=0;b<sz;b++){
int e=0,w=1,&x=T[b];
for(int i=0;i<lg;i++){
if((b>>i)&1) e++;
else e--;
if(e<w) e=w,x=i;
}
}
int m=(n*2+lg-1)/lg;
int h=1;
while((1<<h)<m) h++;
// dat.assign(h,vector<int>(m,-1));
// ht.assign(m+1,0);
for(int j=2;j<=m;j++) ht[j]=ht[j>>1]+1;
for(int j=0;j<n*2;j++){
if(dat[0][j/lg]<0) dat[0][j/lg]=j;
dat[0][j/lg]=comp(dat[0][j/lg],j);
}
for(int i=1,p=1;i<h;i++,p<<=1)
for(int j=0;j<m;j++)
dat[i][j]=comp(dat[i-1][j],dat[i-1][min(j+p,m-1)]);
}
inline int cs(int a,int b){
int l=b-a;
return comp(dat[ht[l]][a],dat[ht[l]][b-(1<<ht[l])]);
}
inline int es(int i,int l,int r){
int x=r-i*lg+1,y=l-i*lg;
int b=(((B[i]|(ms<<x))>>y)|(ms<<(lg-y)))&ms;
return l+T[b];
}
inline int ls(int i,int l){
int k=l-i*lg;
int b=((B[i]>>k)|(ms<<(lg-k)))&ms;
return l+T[b];
}
inline int rs(int j,int r){
int k=r-j*lg+1;
int b=(B[j]|(ms<<k))&ms;
return j*lg+T[b];
}
inline int rmq(int l,int r){
int i=l/lg,j=r/lg;
if(i==j) return es(i,l,r);
if(i+1==j) return comp(ls(i,l),rs(j,r));
return comp(ls(i,l),cs(i+1,j),rs(j,r));
}
int lca(int l,int r){
if(l==r) return l;
if(D[l]>D[r]) swap(l,r);
int x=D[l],y=D[r];
int m=rmq(x,y);
return m==x?l:A[m];
}
inline int distance(int u,int v){
return E[D[u]]+E[D[v]]-E[D[lca(u,v)]]*2;
}
};
//INSERT ABOVE HERE
int xs[MAX],ys[MAX],zs[MAX];
signed main(){
int n,q;
cin>>n>>q;
LCA G(n);
for(int i=1;i<n;i++){
int a,b;
cin>>a>>b;
a--;b--;
G.add_edge(a,b);
}
G.build(0);
for(int i=0;i<q;i++) cin>>xs[i]>>ys[i]>>zs[i],xs[i]--;
for(int i=0;i<q;i++){
long long res=0;
int v=xs[i];
for(int j=0;j<i;j++)
if(G.distance(v,xs[j])<=ys[j]) res+=zs[j];
cout<<res<<"\n";
}
cout<<flush;
return 0;
}
beet