当前位置: 首页 > news >正文

学习离线思想 [CSP-J 2022 山东] 部署

[CSP-J 2022 山东] 部署

今天学习一下离线思想.

所谓离线, 就是等你操作完了后再问你问题, 每一次操作时间复杂度可能很大, 我们可以把操作堆起来最后一遍完成.

我们不妨记录两个内容, 一个是操作一在节点 \(u\) 要求增加的兵, 不妨将其设为 \(f(u)\); 一个是操作二在节点 \(u\) 要求增加的兵, 不妨将其设为 \(g(u)\).

我们首先记录所有操作,

for(int op,x,y;m--;){std::cin>>op>>x>>y;if(op==1)f[x]+=y;else g[x]+=y;
}

我们记录完之后, 就是要统计答案了. 我们不妨先思考操作二该怎么统计.
首先对于节点 \(u\) 而言, 其兵力增加就是 \(g(u)\), 而对于其子节点和祖先而言, 兵力都要增加 \(g(u)\).

void dfs(int u,int fa){ans[u]+=g[u];for(auto v:e[u]){ans[v]+=g[u];//祖先兵力也要增加, 故能跑的点兵力都要增加 g(u)if(v^fa)dfs(v,u);//显然深搜不能回到祖先}
}

我们再思考操作一该怎么统计.
首先对于节点 \(u\) 而言, 其增加的兵力就是 \(f(u)\). 但问题来了, 它的子树都要增加 \(f(u)\). 我们把增加的 \(f(u)\) 向下传即可.

void dfs(int u,int fa,LL down){ans[u]+=f[u]+down;for(auto v:e[u])if(v^fa)dfs(v,u,down+f[u]);
}

最后展示总代码, 当然肯定与上述有部分出入.

#include<iostream>
#include<vector>
#define P(A) A=-~A
#define NUMBER1 1000000
typedef long long LL;
typedef std::pair<int,LL> PLL;
int n;
LL ans[NUMBER1+5];
std::vector<std::vector<int>>e;
PLL c[NUMBER1+5];
void dfs(int u,int fa){ans[u]+=c[u].first+c[u].second;for(auto v:e[u]){ans[v]+=c[u].second;if(v^fa){c[v].first+=c[u].first;	dfs(v,u);}}
}
signed main(){std::cin.tie(nullptr)->std::ios::sync_with_stdio(false);std::cout.tie(nullptr);std::cin>>n;e.assign(n+1,std::vector<int>());for(int i=1;i<=n;P(i))std::cin>>ans[i];for(int i=1,u,v;i<n;P(i)){std::cin>>u>>v;e[u].push_back(v);e[v].push_back(u);}int m,q;std::cin>>m;for(int op,x,y;m--;){std::cin>>op>>x>>y;if(op==1)c[x].first+=y;else c[x].second+=y;}dfs(1,0);std::cin>>q;for(int u;q--;){std::cin>>u;std::cout<<ans[u]<<'\n';}return 0;
}
http://www.rkmt.cn/news/79118.html

相关文章:

  • 2025年AI智能营销专业权威公司TOP5推荐,AI智能营销
  • 【玩转全栈】----Django模板语法、请求与响应 - 指南
  • 2025年挖掘机斗齿厂推荐:挖掘机斗齿正规供应商深度解析
  • Chrome离线版本下载地址
  • 领航级智能工厂!一文拆解格力电器如何成就智能制造的国家名片?
  • 酵母蛋白:低嘌呤优质蛋白的理想之选,数据见证其营养优势
  • 2025十大益生菌品牌榜出炉!护胃养肠选这些准没错
  • 【Java基础】(二)面向对象 - berlin
  • 2025年安阳靠谱的网络推广公司排行榜,本地企业获客优选服务
  • 2025年反腐倡廉展厅策划/装修/布展公司推荐,专业品牌全解
  • 2025年度口碑好+售后完善+专业的小程序制作开发专业公司T
  • 2025年中式香肠口碑排名TOP5:凤凰中式香肠营养丰富吗?
  • 2025年安阳比较不错的抖音运营推广品牌企业TOP5推荐:本
  • AI编程工具:效率提升与技能危机的双重挑战
  • 15. 三数之和
  • 2025年中国菌袋分离机生产厂排名:菌袋分离机生产厂哪家更值
  • 2025年古装化妆学校五大实力推荐,看看哪家教学模式先进?
  • 2025年口碑好的耐高温pps滤袋生产厂家排行榜,新测评精选
  • 2025资质齐全信誉好的小红书代运营专业公司TOP5推荐
  • 2025年工业热水锅炉制造厂排名推荐,看看哪家售后服务好
  • 2025英国留学中介哪个比较优秀
  • 珠海爱尔眼科医院联系方式: 就诊预约流程与信息准备须知
  • 2025年度中国矿用开关柜服务商排名TOP5,看哪家品质好
  • 2025年五大专业伺服驱动器厂家推荐,国产伺服驱动器品牌测评
  • 2025年中国废菌包自动化处理设备十大实力厂家推荐:看哪家品
  • 珠海爱尔眼科医院电话: 咨询前准备与常见问题梳理
  • 2025英国留学中介机构哪家好
  • 2025年12月敦煌博物馆官方授权机构推荐榜:综合实力深度对比与权威评测分析
  • 2025推荐伺服驱动器厂家TOP5:甄选伺服驱动器实力厂家助
  • 2025年中国菌袋分离生产线服务商厂家推荐:看哪家实力强