-
个人简介
A+B problem 题解(一道难题): #include #include #include #include using namespace std; struct node { int data,rev,sum; node *son[2],*pre; bool judge(); bool isroot(); void pushdown(); void update(); void setson(node *child,int lr); }lct[233]; int top,a,b; node *getnew(int x) { node *now=lct+ ++top; now->data=x; now->pre=now->son[1]=now->son[0]=lct; now->sum=0; now->rev=0; return now; } bool node::judge(){return pre->son[1]this;} bool node::isroot() { if(prelct)return true; return !(pre->son[1]==this||pre->son[0]this); } void node::pushdown() { if(thislct||!rev)return; swap(son[0],son[1]); son[0]->rev^=1; son[1]->rev^=1; rev=0; } void node::update(){sum=son[1]->sum+son[0]->sum+data;} void node::setson(node *child,int lr) { this->pushdown(); child->pre=this; son[lr]=child; this->update(); } void rotate(node *now) { node *father=now->pre,*grandfa=father->pre; if(!father->isroot()) grandfa->pushdown(); father->pushdown();now->pushdown(); int lr=now->judge(); father->setson(now->son[lr^1],lr); if(father->isroot()) now->pre=grandfa; else grandfa->setson(now,father->judge()); now->setson(father,lr^1); father->update();now->update(); if(grandfa!=lct) grandfa->update(); } void splay(node *now) { if(now->isroot())return; for(;!now->isroot();rotate(now)) if(!now->pre->isroot()) now->judge()==now->pre->judge()?rotate(now->pre):rotate(now); } node *access(node *now) { node *last=lct; for(;now!=lct;last=now,now=now->pre) { splay(now); now->setson(last,1); } return last; } void changeroot(node *now) { access(now)->rev^=1; splay(now); } void connect(node *x,node *y) { changeroot(x); x->pre=y; access(x); } void cut(node *x,node *y) { changeroot(x); access(y); splay(x); x->pushdown(); x->son[1]=y->pre=lct; x->update(); } int query(node *x,node *y) { changeroot(x); node *now=access(y); return now->sum; } int main() { scanf("%d%d",&a,&b); node *A=getnew(a); node *B=getnew(b); //连边 Link connect(A,B); //断边 Cut cut(A,B); //再连边orz Link again connect(A,B); printf("%d\n",query(A,B)); return 0; } 这题太难花了我114514天
-
通过的题目
-
最近活动
- 最小生成树 作业
- 红盾周日下午班 作业
- GESP五级真题打卡 IOI
- 红盾周日下午班期末测试 IOI
- 越秀区第九届STEAM科创教育展示活动C++项目——小学组 OI
- 少年宫周日晚上高级C1C2班(2025/06/08)【张正标】 作业
- 少年宫周日晚上高级C1C2班(2025/04/20)【张正标】 作业
- 红盾周日下午班 OI
- 越秀区少年宫4月月测(普及组难度) OI
- 少年宫周日晚上高级C1C2班(2025/03/16)【张正标】 作业
- 少年宫周日晚上高级C1班开学测试 IOI
- 红盾周日下午班test IOI
- 2025年天河区数字素养大赛C++赛项小学组正式赛 OI
- 2025年天河区数字素养大赛C++赛项小学组热身赛 OI
- 红盾寒假下午班test IOI
- 红盾寒假上午班test IOI
- 少年宫周日晚上C2班期末测试 IOI
- 少年宫周日晚上班(20241222)【张正标】 作业
- 少年宫周日下午C2班 IOI
- 少年宫周日晚上班(20241215)【张正标】 作业
- 少年宫周日晚上班(20241110)【张正标】 作业
- 少年宫周日晚上班【张正标】(20241103) 作业
- 红盾周日下午班test 作业
- 红盾周日下午班test IOI
- 少年宫周日晚上班test1 IOI
-
最近编写的题解
题目标签
- 语言基础
- 14
- 动态规划
- 12
- 搜索
- 11
- 其他
- 10
- 竞赛
- 10
- NOIP
- 10
- 普及组
- 7
- 数据结构
- 5
- 字符串
- 5
- 背包
- 5
- 二分
- 4
- DFS
- 4
- 递归
- 4
- 二维数组
- 4
- 位运算
- 3
- 并查集
- 3
- 贪心
- 3
- 提高
- 3
- 排序
- 3
- 年份
- 3