树链剖分:(来源:树的统计)

#include<bits/stdc++.h>
#define rint register int
using namespace std;
inline void read(int &A)
{
A=;int B=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')B=-;ch=getchar();}
while(ch>=''&&ch<=''){A=(A<<)+(A<<)+ch-'';ch=getchar();}
A=A*B;return ;
}
int n,q,v[],w[],nxt[],first[],tot;
int f[],d[],siz[],son[];
int id[],rk[],cnt,tp[],ans;
char ch[];
struct node{int k,mx;}t[<<];
inline void build_line(int uu,int vv)
{
v[++tot]=vv,nxt[tot]=first[uu];
first[uu]=tot;
}
inline void dfs(int x,int fa,int dep)
{
f[x]=fa,d[x]=dep,siz[x]=;
for(rint i=first[x];i;i=nxt[i])
{
int y=v[i];if(y==fa)continue;
dfs(y,x,dep+);siz[x]+=siz[y];
if(siz[y]>siz[son[x]])son[x]=y;
}
return ;
}
inline void Dfs(int x,int t)
{
tp[x]=t,id[x]=++cnt,rk[cnt]=x;
if(!son[x])return ;Dfs(son[x],t);
for(rint i=first[x];i;i=nxt[i])
if(v[i]!=son[x]&&v[i]!=f[x])
Dfs(v[i],v[i]);
return ;
}
inline void update(int k)
{
t[k].k=t[k<<].k+t[k<<|].k;
t[k].mx=max(t[k<<].mx,t[k<<|].mx);
return ;
}
inline void build(int k,int l,int r)
{
if(l==r){t[k].k=t[k].mx=w[rk[l]];return ;}
int mid=(l+r)>>;
build(k<<,l,mid);build(k<<|,mid+,r);
update(k);return ;
}
inline int Qsum(int k,int l,int r,int L,int R)
{
if(L<=l&&r<=R)return t[k].k;
int mid=(l+r)>>,res=;
if(L<=mid)res+=Qsum(k<<,l,mid,L,R);
if(R>mid)res+=Qsum(k<<|,mid+,r,L,R);
return res;
}
inline int Qmax(int k,int l,int r,int L,int R)
{
if(L<=l&&r<=R)return t[k].mx;
int mid=(l+r)>>,res=-0x7fffffff;
if(L<=mid)res=max(res,Qmax(k<<,l,mid,L,R));
if(R>mid)res=max(res,Qmax(k<<|,mid+,r,L,R));
return res;
}
inline void change(int k,int l,int r,int p,int dat)
{
if(l==r){t[k].k=t[k].mx=dat;return ;}
int mid=(l+r)>>;
if(p<=mid)change(k<<,l,mid,p,dat);
else change(k<<|,mid+,r,p,dat);
update(k);return ;
}
inline int get_sum(int x,int y)
{
int Sum=,fx=tp[x],fy=tp[y];
while(fx!=fy)
{
if(d[fx]>=d[fy])
{
Sum+=Qsum(,,n,id[fx],id[x]);
x=f[fx],fx=tp[x];
}
else
{
Sum+=Qsum(,,n,id[fy],id[y]);
y=f[fy],fy=tp[y];
}
}
if(id[x]<=id[y])Sum+=Qsum(,,n,id[x],id[y]);
else Sum+=Qsum(,,n,id[y],id[x]);
return Sum;
}
inline int get_max(int x,int y)
{
int Max=-0x7fffffff,fx=tp[x],fy=tp[y];
while(fx!=fy)
{
if(d[fx]>=d[fy])
{
Max=max(Max,Qmax(,,n,id[fx],id[x]));
x=f[fx],fx=tp[x];
}
else
{
Max=max(Max,Qmax(,,n,id[fy],id[y]));
y=f[fy],fy=tp[y];
}
}
if(id[x]<=id[y])Max=max(Max,Qmax(,,n,id[x],id[y]));
else Max=max(Max,Qmax(,,n,id[y],id[x]));
return Max;
}
int main()
{
// freopen("count1.in","r",stdin);
// freopen("my.out","w",stdout);
read(n);
for(rint i=,ST,EN;i<n;++i)
{
read(ST),read(EN);
build_line(ST,EN);
build_line(EN,ST);
}
for(rint i=;i<=n;++i)read(w[i]);
dfs(,,);Dfs(,);build(,,n);
read(q);
for(rint i=,uu,vv;i<=q;++i)
{
scanf("%s",ch);
if(ch[]=='C')
{
read(uu),read(vv);
change(,,n,id[uu],vv);
}
else
{
ans=;read(uu),read(vv);
if(ch[]=='M')ans=get_max(uu,vv);
else ans=get_sum(uu,vv);
printf("%d\n",ans);
}
}
}

树链剖分模板

tarjan点双

inline void tarjan(int x)
{
dfn[x]=low[x]=++cnt;s.push(x);
if(x==root && firsty[x]==)
{
dcc[++totq].clear();
dcc[totq].push_back(x);
return ;
}
int flag=;
for(rint i=firsty[x];i;i=edge[i].nxt)
{
int y=edge[i].v;
if(!dfn[y])
{
tarjan(y);low[x]=min(low[x],low[y]);
if(low[y]>=dfn[x])
{
flag++;
if(x!=root||flag>)cut[x]=true;
totq++;int z;
dcc[totq].clear();
do{
z=s.top();s.pop();
dcc[totq].push_back(z);
}while(z!=y);
dcc[totq].push_back(x);
}
}
else low[x]=min(low[x],dfn[y]);
}
}

tarjan点双模板

二分图匹配(带注释)

int point(int u)//这个函数的作用是寻找增广路和更新cx,xy数组,如果找到了增广路,函数返回1,找不到,函数返回0。
{
for(int v=;v<=ny;v++)//依次遍历右边的所有顶点
{
if(e[u][v]&&!visited[v])//条件一:左边的u顶点和右边的v顶点有连通边,条件二:右边的v顶点在没有被访问过,这两个条件必须同时满足
{
visited[v]=;//将v顶点标记为访问过的
if(cy[v]==-||point(cy[v]))//条件一:右边的v顶点没有左边对应的匹配的点,条件二:以v顶点在左边的匹配点为起点能够找到一条增广路(如果能够到达条件二,说明v顶点在左边一定有对应的匹配点)。
{
cx[u]=v;//更新cx,cy数组
cy[v]=u;
return ;
}
}
}
return ;//如果程序到达了这里,说明对右边所有的顶点都访问完了,没有满足条件的。
}

二分图匹配模板

中国剩余定理

LL exgcd(LL a,LL b,LL &x,LL &y)
{
if(!b)
{
x=;y=;
return a;
}
LL res=exgcd(b,a%b,x,y);
LL t=x;
x=y;
y=t-a/b*x;
return res;
}
LL China()
{
LL m=;
LL res=;
LL x,y;
for(rint i=;i<=n;i++)m*=a[i];
for(rint i=;i<=n;i++)
{
LL tmp=m/a[i];
exgcd(tmp,a[i],x,y);
res=(res+tmp*x*b[i])%m;
}
res=(res+m)%m;
return res;
}

中国剩余定理模板

随机推荐

  1. java反射技术主要实现类有哪些,作用分别是什么

    Java反射技术主要实现类有哪些,作用分别是什么? 在JDK中,主要由以下类来实现Java反射机制,这些类都位于java.lang.reflect包中 1)Class类:代表一个类 2)Field 类 ...

  2. Django之Form操作

    一.Form基础 (一)Form的作用 Django的Form主要有以下几大作用: 生成HTML标签 验证用户数据(显示错误信息) Form提交保留上次提交数据 初始化页面显示数据 (二)实例 一般网 ...

  3. mybatis 多表查询sql

    在使用spring,spring mvc,mybatis时,mybatis链接数据库做多表查询的时候,sql语句中直接使用left join等链接字符就可以 链接多个表,参数类型是parameterT ...

  4. 关键字this super final static

    this关键字 1.this代表通过当前类实例化成的对象. 2.通过this来获取当前类的属性和方法 3.通过this和区分成员变量和局部变量 4.通过this(参数),调用当前类的构造方法 注意:通 ...

  5. Java——类的成员之五:内部类

    3.6 类的成员之五:内部类 3.6.1 静态内部类 ①静态内部类可以等同看做静态变量. ②内部类重要的作用:可以访问外部类中私有的数据. ③静态内部类可以直接访问外部类的静态数据,无法直接访问成员. ...

  6. NOIP2019模拟2019.9.20】膜拜大会(外向树容斥,分类讨论)

    传送门. 题解: 我果然是不擅长分类讨论,心态被搞崩了. 注意到\(m<=n-2\),意味着除了1以外的位置不可能被加到a[1]两遍. 先考虑个大概: 考虑若存在\(x,x-1,-,2\)(有序 ...

  7. DELPHI常用类型及定义单元

    Controls Application (the variable not a type) Forms Beep SysUtils or Windows (different functions) ...

  8. AcWing 156. 矩阵 (哈希二维转一维查询)打卡

    给定一个M行N列的01矩阵(只包含数字0或1的矩阵),再执行Q次询问,每次询问给出一个A行B列的01矩阵,求该矩阵是否在原矩阵中出现过. 输入格式 第一行四个整数M,N,A,B. 接下来一个M行N列的 ...

  9. php5模块pdo、pdo_mysql、mysqli的添加

    一.环境LAMP都是源码安装,PHP安装的时候没有配置pdo_mysql和mysqli,pdo是php5默认带的.PHP5的源码都在,只需要把php5的模块功能扩展就可以了. php源码目录:/usr ...

  10. Linux 下tomcat+jdk+mysql安装

    JDK 1.用xftp把 jdk1.8.0_65上传到local下 给他赋予最高权限 1)切换到顶级目录    cd ~ 2)然后切换到上级目录 cd .. 3)切换到local路径下  cd /us ...