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

源丰建设有限公司网站京津冀协同发展规划纲要全文 pdf

源丰建设有限公司网站,京津冀协同发展规划纲要全文 pdf,有趣的网站小游戏,免费网站建设协议传送门:牛客 题目描述: 华华看书了解到#xff0c;一起玩养成类的游戏有助于两人培养感情。所以他决定和月月一起种一棵树。因为华华现在也是信息学高手了#xff0c;所以他们种的树是信息学意义下的。 华华和月月一起维护了一棵动态有根树#xff0c;每个点有一个权值。刚…传送门:牛客 题目描述: 华华看书了解到一起玩养成类的游戏有助于两人培养感情。所以他决定和月月一起种一棵树。因为华华现在也是信息学高手了所以他们种的树是信息学意义下的。 华华和月月一起维护了一棵动态有根树每个点有一个权值。刚开存档的时候树上只有 0 号节点权值为 0 。接下来有两种操作 操作 1输入格式1 i表示月月氪金使节点 i 长出了一个新的儿子节点权值为0编号为当前最大编号 1也可以理解为当前是第几个操作 1新节点的编号就是多少。 操作 2输入格式2 i a表示华华上线做任务使节点 i 的子树中所有节点即它和它的所有子孙节点权值加 a 。 但是月月有时会检查华华有没有认真维护这棵树会作出询问 询问 3输入格式3 i华华需要给出 i 节点此时的权值。 华华当然有认真种树了不过还是希望能写个程序以备不时之需。 输入: 9 1 0 2 0 1 3 0 3 1 1 0 1 1 2 0 2 3 1 3 3 输出: 1 1 3 2树上操作,使用树链剖分线段树进行解决 对于操作2和操作3,我们可以将树形结构分解成线性结构然后使用线段树进行维护区间修改即可.对于分解树形结构的算法可以使用dfs序进行解决,也可以使用树链剖分进行解决.两者相比,dfs序的代码量更短,但是树链剖分能解决的情况更为普遍,所以对于本题来说,博主使用的树链剖分算法 对于操作一,我们发现我们需要动态的对树进行加点操作,对于这种操作,我们发现很难进行维护.所以我们考虑进行离线维护.对于所有的加点操作,我们都假设全部都已经完成.建一颗最终的树.然后对于这些树来说,我们对此每一个节点使用操作2. 此时肯定会发现这种做法存在这样的一个问题,因为我们此时对uuu的所有节点增加了一个权值,但是对于uuu的一些节点(假设为v)来说,可以本来是在这个操作之后才产生的,所以此时我们的操作是错误的.所幸的是此时我们需要统计的只是单点的全职,所以此时当我们v还未出现之前,我们直接将v的权值改变了对于我们的查询来说并没有问题,因为我们此时根本不会查询这个点.然后当我们的这个点出现之后,只要将这个点的权值归0即可,此时我们的v节点就可以保证正确性了 为了操作方便,可以将所有节点的编号加一 下面是具体的代码部分: #include bits/stdc.h using namespace std; typedef long long ll; #define root 1,n,1 #define ls rt1 #define rs rt1|1 #define lson l,mid,rt1 #define rson mid1,r,rt1|1 inline ll read() {ll x0,w1;char chgetchar();for(;ch9||ch0;chgetchar()) if(ch-) w-1;for(;ch0ch9;chgetchar()) xx*10ch-0;return x*w; } #define maxn 1000000 const double eps1e-8; #define int_INF 0x3f3f3f3f #define ll_INF 0x3f3f3f3f3f3f3f3f int fa[maxn],dep[maxn],max_son[maxn],Size[maxn]; vectorintedge[maxn]; void dfs1(int u,int pre_u) {Size[u]1;for(int i0;iedge[u].size();i) {int vedge[u][i];if(vpre_u) continue;dep[v]dep[u]1;dfs1(v,u);fa[v]u;Size[u]Size[v];if(Size[v]Size[max_son[u]]) {max_son[u]v;}} } int top[maxn],id[maxn],rev[maxn],tot0; void dfs2(int u,int t) {top[u]t;id[u]tot;rev[tot]u;if(!max_son[u]) return ;dfs2(max_son[u],t);for(int i0;iedge[u].size();i) {int vedge[u][i];if(vfa[u]||vmax_son[u]) continue;dfs2(v,v);} } struct Segment_tree{int l,r,sum,lazy; }tree[maxn*4];int w[maxn]; void build(int l,int r,int rt) {tree[rt].ll;tree[rt].rr;tree[rt].sumtree[rt].lazy0;if(lr) return ;int mid(lr)1;build(lson);build(rson); } void pushup(int rt) {tree[rt].sumtree[ls].sumtree[rs].sum; } void change(int rt,int val) {int lentree[rt].r-tree[rt].l1;tree[rt].sumlen*val;tree[rt].lazyval; } void pushdown(int rt) {change(ls,tree[rt].lazy);change(rs,tree[rt].lazy);tree[rt].lazy0; } void update(int l,int r,int rt,int val) {if(tree[rt].lltree[rt].rr) {change(rt,val);return ;}if(tree[rt].lazy) pushdown(rt);int mid(tree[rt].ltree[rt].r)1;if(rmid) update(l,r,ls,val);else if(lmid) update(l,r,rs,val);else update(l,mid,ls,val),update(mid1,r,rs,val);pushup(rt); } int query(int pos,int rt) {if(tree[rt].lpostree[rt].rpos) {return tree[rt].sum;}if(tree[rt].lazy) pushdown(rt);int mid(tree[rt].ltree[rt].r)1;if(posmid) return query(pos,ls);else return query(pos,rs); } struct OPT{int opt,pos,Date; }opt[maxn]; int main() {int mread();int cnt1;for(int i1;im;i) {opt[i].optread(); if(opt[i].opt1) {opt[i].posread();edge[opt[i].pos1].push_back(cnt);opt[i].Datecnt;}else if(opt[i].opt2) {opt[i].posread();opt[i].Dateread();}else {opt[i].posread();}}dfs1(1,0);dfs2(1,1);build(1,tot,1);for(int i1;im;i) {if(opt[i].opt1) {int uopt[i].Date;int tquery(id[u],1);update(id[u],id[u],1,-t);}else if(opt[i].opt2) {int uopt[i].pos1;update(id[u],id[u]Size[u]-1,1,opt[i].Date);}else {int uopt[i].pos1;printf(%d\n,query(id[u],1));}}return 0; }
http://www.hkea.cn/news/14387853/

相关文章:

  • 网站开发的类型seo简历
  • 哈尔滨网站建设一薇ls15227百度公司在哪
  • 重庆怎么自己做网站网站的优化
  • 网上商城网站建设规划电商网站html模板
  • 漯河做网站龙岗网站制作讯息
  • 电子商务系统建设网站策划书双辽建设局网站
  • 全网推广平台seo手机关键词排行推广
  • 深圳建设造价信息网站免费下载简历自己填写
  • 央企八大设计院模板网站如何做seo
  • 网站服务器使用项目网格化管理方案
  • 做的网站 如何在局域网内访问北京市注册公司流程最新
  • 江苏省招投标办法建设厅网站南宁外包seo服务
  • 做渠道的网站有哪些方面做网站规避什么
  • 做的很好的画册网站seo网站布局
  • 怎样做网站哪家购物网站做的好
  • 东莞技术支持 骏域网站建设三丰云做网站步骤
  • 雄县哪里有建设网站的wordpress订单推送微信
  • 如何给网站续费网站建设着
  • 有域名后怎么建网站中关村在线网站的建设
  • 怎么用自己的网站做邮箱产品设计出来好找工作吗
  • 博客网站排名大全番禺广州网站建设
  • 企业网站建立流程的第一步是做软件赚钱吗
  • 域名如何绑定网站pc 移动网站 模板
  • 广州做网站公司哪家好腾讯云wordpress插件下载
  • 中国建设招标信息网站开网店详细步骤
  • 网站策划的知识网站开发网上悼念
  • 深圳做网站乐云seo598做二手设备的网站
  • 网站建设与网页设计制作wordpress代码缩进
  • idc销售网站php源码建立网站的详细步骤知乎
  • 个人网站开发公司seo网站架构设计