ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

体系课-Go+Python双语言混合开发 盯紧技术先机 抓紧高薪机遇

2021-04-03 20:54:27  阅读:248  来源: 互联网

标签:ch 盯紧 fa Python void int IL Go ls


download:体系课-Go+Python双语言混合开发 盯紧技术先机 抓紧高薪机遇

适合人群

首次开发微服务,高并发项目
从1年初级开发进阶高级工程师
提高crud水平,无自研框架底层原理经验
技术栈单一,缺乏就业竞争力
想攻克分布式常见面试问题

技术储备要求

具备Python基础
Mysql数据库
任意语言Web后端项目经验
IL void access(int x) {//打通從根節點到x的途径,x最深
for(R y=0; x; x=fa(y=x)) {
splay(x),rs(x)=y,pushup(x);
}
}
Make_root(x):將x變成根節點

IL void makeroot(int x) {//把x變爲原樹的根
access(x),splay(x),Rev(x);
}
Find_root(x):找到x所在的根節點

IL int findroot(int x) {//找到x的原樹的根
access(x),splay(x);
while(ls(x)) pushdown(x),x=ls(x);
return x;
}
Spilt(x,y):將x到y的途径變成實邊途径

IL void split(int x,int y) {//y維護x-y途径上的信息
makeroot(x),access(y),splay(y);
}
Link(x,y):若x,y不連通,則參加(x,y)這條邊

IL void link(int x,int y) {
makeroot(x);if(findroot(y)!=x) fa(x)=y;
}
Cut(x,y):若x,y之間有邊,則删掉該邊

IL void cut(int x,int y) {
split(x,y);
if(fa(x)==y&&rs(x)==0) fa(x)=ls(y)=0,pushup(y);
}
Isroot(x):判別x能否是所在splay的根節點

IL int nroot(int x) //返回1阐明x不是根,返回0阐明x是根
{return ls(fa(x))==x||rs(fa(x))==x;}
P3690 【模板】Link Cut Tree (動態樹)
萌新寫代码~码風跟喻隊學的

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-BOtyn2Wj-1616093171049)()]```
1 #include<bits/stdc++.h>
2 #define IL inline
3 #define R register int
4 #define ls(x) a[x].ch[0]
5 #define rs(x) a[x].ch[1]
6 #define fa(x) a[x].fa
7
8 using namespace std;
9 const int N=1e5+5,inf=0x3f3f3f3f;
10
11 IL int read() {
12 int f=1;
13 char ch;
14 while((ch=getchar())<‘0’||ch>‘9’) if(ch==’-’) f=-1;
15 int res=ch-‘0’;
16 while((ch=getchar())>=‘0’&&ch<=‘9’) res=res10+ch-‘0’;
17 return resf;
18 }
19
20 int n,m;
21 struct hh {
22 int ch[2],fa,val,rev,sum;
23 } a[N];
24
25 IL int chk(int x) {return x==rs(fa(x));}
26 IL void Rev(int x) {swap(ls(x),rs(x));a[x].rev^=1;}
27 IL void pushup(int x) {a[x].sum=a[ls(x)].suma[rs(x)].suma[x].val;}
28 IL int nroot(int x) //返回1阐明x不是根,返回0阐明x是根
29 {return ls(fa(x))==x||rs(fa(x))==x;}
30
31 IL void pushdown(int x) {
32 if(a[x].rev) {
33 a[x].rev=0;
34 if(ls(x)) Rev(ls(x));
35 if(rs(x)) Rev(rs(x));
36 }
37 }
38
39 IL void pushall(int x) {
40 if(nroot(x)) pushall(fa(x));
41 pushdown(x);
42 }
43
44 IL void rotate(int x) {
45 int y=fa(x),z=fa(y),k=chk(x),w=a[x].ch[k^1];
46 if(nroot(y)) a[z].ch[chk(y)]=x;fa(x)=z;
47 if(w) fa(w)=y;a[y].ch[k]=w;
48 fa(y)=x;a[x].ch[k^1]=y;
49 pushup(y);pushup(x);
50 }
51
52 IL void splay(int x) {//把x轉到splay的根
53 pushall(x);
54 while(nroot(x)) {
55 int y=fa(x);
56 if(nroot(y)) rotate(chk(x)^chk(y)?x:y);
57 rotate(x);
58 }
59 }
60
61 IL void access(int x) {//打通從根節點到x的途径,x最深
62 for(R y=0; x; x=fa(y=x)) {
63 splay(x),rs(x)=y,pushup(x);
64 }
65 }
66
67 IL void makeroot(int x) {//把x變爲原樹的根
68 access(x),splay(x),Rev(x);
69 }
70
71 IL int findroot(int x) {//找到x的原樹的根
72 access(x),splay(x);
73 while(ls(x)) pushdown(x),x=ls(x);
74 return x;
75 }
76
77 IL void split(int x,int y) {//y維護x-y途径上的信息
78 makeroot(x),access(y),splay(y);
79 }
80
81 IL void link(int x,int y) {
82 makeroot(x);if(findroot(y)!=x) fa(x)=y;
83 }
84
85 IL void cut(int x,int y) {
86 split(x,y);
87 if(fa(x)y&&rs(x)0) fa(x)=ls(y)=0,pushup(y);
88 }
89
90 int main() {
91 n=read();
92 m=read();
93 for(R i=1; i<=n; ++i) a[i].val=a[i].sum=read();
94 while(m–) {
95 int op=read(),x=read(),y=read();
96 if(!op) split(x,y),printf("%d\n",a[y].sum);
97 else if(op1) link(x,y);
98 else if(op2) cut(x,y);
99 else makeroot(x),a[x].val=y,pushup(x);
100 }
101 return 0;
102 }

标签:ch,盯紧,fa,Python,void,int,IL,Go,ls
来源: https://blog.51cto.com/15134636/2682959

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有