[模板]点分治
code
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = 1e5 + 7;
const int inf = 1e7;
int n, m, mx[maxn], siz[maxn], dis[maxn], rem[maxn], qu[1010];
int sum, root, ans, q[maxn];
bool vis[maxn], test[inf], judge[inf];
inline int read()
{
int x = 0, f = 1;
char ch = getchar();
while(ch < '0' || ch > '9')
{
if(ch == '-')
{
f = -1;
}
ch = getchar();
}
while(ch >= '0' && ch <= '9')
{
x = (x << 1) + (x << 3) + (ch^48);
ch = getchar();
}
return x * f;
}
struct node
{
int next, to, w;
}a[maxn<<1];
int head[maxn], len;
void add(int x, int y, int w)
{
a[++len].to = y; a[len].next = head[x]; a[len].w = w;
head[x] = len;
}
void findroot(int x, int fa)
{
siz[x] = 1; mx[x] = 0;
for(int i=head[x]; i; i=a[i].next)
{
int v = a[i].to;
if(v == fa || vis[v]) continue;
findroot(v, x);
siz[x] += siz[v];
mx[x] = max(mx[x], siz[v]);
}
mx[x] = max(mx[x], sum-siz[x]);
if(mx[x] < mx[root]) root = x;
}
void getdis(int u, int fa)
{
rem[++rem[0]] = dis[u];
for(int i=head[u]; i; i=a[i].next)
{
int v = a[i].to;
if(v == fa || vis[v]) continue;
dis[v] = dis[u] + a[i].w;
getdis(v, u);
}
}
void calc(int x)
{
int p = 0;
for(int i=head[x]; i; i=a[i].next)
{
int v = a[i].to;
if(vis[v]) continue;
rem[0] = 0; dis[v] = a[i].w;
getdis(v, x);
for(int j=rem[0]; j; j--)
{
for(int k=1; k<=m; k++)
{
if(qu[k] >= rem[j])
{
test[k] |= judge[qu[k]-rem[j]];
}
}
}
for(int j=rem[0]; j; j--)
{
q[++p] = rem[j]; judge[rem[j]] = 1;
}
}
for(int i=1; i<=p; i++) judge[q[i]] = 0;
}
void solve(int x)
{
vis[x] = judge[0] = 1; calc(x);
for(int i=head[x]; i; i=a[i].next)
{
int v = a[i].to;
if(vis[v]) continue;
sum = siz[v]; root = 0;
findroot(v, 0); solve(root);
}
}
int main()
{
n = read(); m = read();
for(int i=1; i<n; i++)
{
int x = read(), y = read(), w = read();
add(x, y, w); add(y, x, w);
}
for(int i=1; i<=m; i++)
{
qu[i] = read();
}
mx[0] = sum = n;
findroot(1, 0);
solve(root);
for(int i=1; i<=m; i++)
{
if(test[i]) printf("AYE\n");
else printf("NAY\n");
}
return 0;
}
时光花火,水月星辰
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
· 全网最简单!3分钟用满血DeepSeek R1开发一款AI智能客服,零代码轻松接入微信、公众号、小程