CF19D(树套树)
1.CF1656E(构造思想)2.P10178(构造思想)3.P10179(构造思想+实现)4.P3963 (平衡树思想)5.P10156(dp思想)6.P3939 (ds实现)7.CF776D(并查集思想)8.CF243A (拆位思想)9.ABC283E (dp思想)10.AT_joi2015ho_b (dp思想)11.P9588 (ds思想)12.CF482B (拆位思想+实现)13.U332154 carbon 题解(期望)14.U329011 trie pi 题解15.[ARC128D](计数dp)16.P1081 (倍增+代码实现技巧)17.CF1537D (博弈论+找规律)18.CF1557D (dx)(dp技巧)19.P3165/P2596(文艺平衡树套路)20.吉司机大杂烩21.ARC149C (构造)
22.CF19D(树套树)
23.网络流大杂烩24.U417376题解25.CF1748E(笛卡尔树)26.[CERC2019] Be Geeks!27.「Cfz Round 2」Binary28.CF1833G29.P1028230.CF1939C31.2024省选OIFC模拟T132.P140733.P10218 魔法手杖34.P165335.取模二题36.CF1699C37.ABC35238.P6627 [省选联考 2020 B 卷] 幸运数字39.P6619 [省选联考 2020 A/B 卷] 冰火战士40.2024PKUSC游记一道非常有意思的树套树。
一眼一个空间时间的树套树,发现过不了。考虑优化。我们发现在中间线段树的地方可以不用平衡树存下来,只记最大值即可。然后我们对于每个横坐标开一颗fhq,然后分出段区间,这些区间的最大值大于给定点的纵坐标。然后用二分找到最左的点,然后在这里找到最下的点即可。
void get(int l,int r,int k,int p){
if(l==r){
cout<<a[l]<<" "<<getnxt(l,k)<<"\n";
flag=1;
return;
}
int mid=(l+r)>>1;
if(d[p<<1]>k) get(l,mid,k,p<<1);
else if(d[p<<1|1]>k) get(mid+1,r,k,p<<1|1);
}
void getsum(int l,int r,int p,int s,int t,int k){
if(flag==1) return;
if(l>=s&&r<=t){
//cout<<l<<"-"<<r<<"\n";
if(d[p]>k) get(l,r,k,p);
return;
}
int mid=(l+r)>>1;
if(s<=mid) getsum(l,mid,p<<1,s,t,k);
if(t>mid) getsum(mid+1,r,p<<1|1,s,t,k);
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?