首页 > 其他分享 >模板

模板

时间:2024-01-16 21:45:31浏览次数:26  
标签:pre return rs int ans inline 模板

周日有模拟赛所以复习若干板子

树状数组
inline int lowbit(int x)
{
    return x&-x;
}//lowbit

inline int ask(int x)
{
    int ans=0;
    while(x)
    {
        ans+=t[x];
        x-=lowbit(x);
    }
    return ans;
}//单点查询

inline void change(int x,int v)
{
    while(x<=N)
    {
        t[x]+=v;
        x+=lowbit(x);
    }
}//单点修改

inline int ask_all(int l,int r)
{
    return(ask(r)-ask(l-1));
}//区间查询

inline void change_all(int l,int r,int x)
{
    change(1,x);change(r+1,-x);
}//区间修改


树状数组区间修改区间查询
inline void change(int p, int x)
{
    for(int i=p;i<=n;i+=i&-i)
        sum1[i]+=x,sum2[i]+=x*p;
}
inline void change_all(int l, int r, int x)
{
    change(l,x),change(r+1,-x);
}
inline int ask(int p)
{
    int ans=0;
    for(int i=p;i;i-= i&-i)
        ans+=(p+1)*sum1[i]-sum2[i];
    return ans;
}
inline int ask_all(int l, int r)
{
    return ask(r)-ask(l-1);
}
线段树
#define p<<1 ls
#define p<<1|1 rs
#define mid (l+r)>>1
inline void push_up(int p)
{
    t[p].pre=t[ls].pre+t[rs].pre;
    t[p].maxl=max(t[ls].maxl,t[ls].pre+t[rs].maxl);
    t[p].maxr=max(t[rs].maxr,t[rs].pre+t[ls].maxr);
    t[p].ans=max(max(t[ls].ans,t[rs].ans),t[ls].maxr+t[rs].maxl);
    return;
}
inline void bulid(int p,int l,int r)
{
    t[p].l=l,t[p].r=r;
    if(l==r) 
    {
        t[p].pre=a[l];
        return;
    }
    int mid=l+r>>1;
    bulid(ls,l,mid);
    bulid(rs,mid+1,r);
    t[p].pre=t[ls].pre+t[rs].pre;
    push_up(p);
}
inline void change(int p,int x,int y,int z)
{
    if(x<=t[p].l && y>=t[p].r)
    {
        t[p].pre+=(int)z*(t[p].r-t[p].l+1);
        return;
    }
    int mid=t[p].l+t[p].r>>1;
    if(x<=mid) change(ls,x,y,z);
    if(y>mid) change(rs,x,y,z);
    t[p].pre=t[ls].pre+t[rs].pre;
    push_up(p);
} 
inline int find(int p,int x,int y)
{
    if(x<=t[p].l && y>=t[p].r) return t[p].pre;
    int mid=t[p].l+t[p].r>>1;
    int ans=0;
    if(x<=mid) ans+=find(ls,x,y);
    if(y>mid) ans+=find(rs,x,y);
    return ans;
} 

快读
inline int read()
{
    int d=1,x=0;char ch;
    while(ch<'0'||ch>'9'){ch=getchar();if(ch=='-')d=-1;};
    while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();};
    return d*x;
}
数论半家桶(超长警告)
inline void exgcd(int a,int b,int &x,int &y)
{
    if (!b)
    {
        x=1;
        y=0;
        return ;
    }
    exgcd(b,a%b,x,y);
    int t=x;
    x=y;
    y=t-a/b*y;
}//exgcd

inline int inv(int x)
{
    return (x%p+x)%p;
}//逆元

inline int gcd(int x,int y)
{
    return __gcd(x,y);
}//gcd
for(int i=1;i*i<=n;++i)
    {
        if(n%i) continue;
        prime[++cnt]=i;
        if(i*i!=n) prime[++cnt]=n/i;
    }
    //线性筛素数

inv[0]=inv[1]=1;
    for(int i=2;i<=n;++i)
       inv[i]=(p-p/i)*inv[p%i]%p;
    //线性处理逆元
inline int qpow(int a,int b,int p)
{
    int ans=1;
    while(b)
    {
        if(b&1) ans=(ans*a)%p;
        a=(a*a)%p;
        b>>=1;
    }  
    return ans;
}//快速幂

inline int p(int a,int b)
{
    int ans=0;
    while(b)
    {
        if(b&1) ans=(ans+a)%p;
        a=(a+a)%p;
        b>>=1;
    }
    return ans%p;
}//龟速乘

inline void Euler(int n)
{
    vis[0]=vis[1]=1;
    for(register int i=2;i<=n;++i)
    {
        if(!vis[i]) 
        prime[++cnt]=i,phi[i]=i-1;
        for(register int j=1;j<=cnt && i*prime[j]<=n;++j)
        {
            vis[i*prime[j]]=1;
            if(i%prime[j]==0)
            {
                phi[i*prime[j]]=phi[i]*prime[j];
                break;
            }
            phi[i*prime[j]]=phi[i]*(prime[j]-1);
        }
    }
}//线性筛欧拉函数

inline int Euler(int n)
{
    int a=n;
    for(int i=2;i*i<=n;++i)
    {
        if(n%i==0)
        {
            a=a/i*(i-1);
            while(n%i==0) n/=i;
        }
    }
    if(n>1) a=a/n*(n-1);
    return a;
}//求n以内欧拉函数总和

inline int lucas(int a,int b)
{
    if(a>b) return 0;
    if(b<=P) return fac[b]%P*ifac[a]%P*ifac[b-a]%P;
    return lucas(a%P,b%P)%P*lucas(a/P,b/P)%P;
}//Lucas定理

    js[0]=1;
    for(register int i=1;i<=n;++i)
        js[i]=js[i-1]*i%p;
    inv[n]=qpow(js[n],p-2);
    inv[0]=1;
    for(register int i=n-1;i>=1;--i)
        inv[i]=(inv[i+1]*(i+1))%p;
inline int C(int n,int m)
{
    return(((js[n]*inv[m])%p)*inv[n-m])%p;
}//预处理求组合数

    d[0]=1,d[1]=0,d[2]=1;
    for(register int i=3;i<=n;++i)
        d[i]=((i-1)*((d[i-1]+d[i-2])%p))%p;
        //错排

inline int CRT()
{
    int p=1,ans=0;
    for(int i=1;i<=n;++i)
        p*=mod[i];
    for(int i=1;i<=n;++i)
        (ans+=(p/mod[i])*inv(p/mod[i],mod[i])*r[i])%=p;
    return (ans%p+p)%p;
}

inline int exCRT()
{
    int p=mod[1];ans=a[1];
    int x,y,c,d;
    for(register int i=2;i<=n;++i)
    {
        x=y=0;
        c=(a[i]-ans%mod[i]+mod[i])%mod[i];
        d=exgcd(p,mod[i],x,y);
        if(!(c%d))
            ans+=(((x+mod[i])%mod[i])*(c/d)%mod[i])*p,
            p=p*mod[i]/gcd(p,mod[i]),
            ans=ans%p;
        else return -1;
    }
    return ans%p;
}//exCRT

inline int exlucas(int n,int m,int p)
{
    int P=p,tot=0;
    int Genshin=sqrt(p);
    for(int i=2;i<=Genshin;i++)
    {
        if(!(P%i))
        {
            int pk=1;
            while(!(P%i))
            {
                pk*=i;P/=i;
            }
            a[++tot]=pk;b[tot]=C(n,m,i,pk);
        }
    }
    if(P!=1)
    {
        a[++tot]=P;b[tot]=C(n,m,P,P);
    }
    int ans=0;
    for(int i=1;i<=tot;++i)
    {
        int M=p/a[i],t=inv(M,a[i]);
        ans=(ans+b[i]*M%p*t%p)%p;
    }
    return ans;
}//exLucas!


恼了,还没复习单调队列和图论。

标签:pre,return,rs,int,ans,inline,模板
From: https://www.cnblogs.com/HSxh/p/17968616

相关文章

  • 17类模板
    类模板类成为类名和类型参数的组合无论是一般类还是模板类,只有调用到的成员函数,才会出现在符号表上。#pragmaonce#include<iostream>#include<cstring>usingnamespacestd;template<typenameT>classSeqStack{//模板名称+类型参数列表=类名称private: T*......
  • Abp vnext FreeSql 生成模板,并提供下载模板接口
    DtoDto设置参考[ExcelImporter(IsLabelingError=true)]publicclassMyDto{ [ImporterHeader(Name="序号")] [ExporterHeader(DisplayName="序号")] publicintId{get;set;}}Controller生成模板[HttpGet("GenerateTemplate")]//[Wr......
  • 仿sina个人轻微博html静态网页模板
    一款最新的仿sina个人微博html静态网页模板(轻博客/轻微博/贴吧主页、qq社交空间主题),模板清新简洁、新颖,包含关注、粉丝、人气、个人资料、文章、视频等。比较适合类似爱装扮空间的女生,二次元动漫、插画绘画等内容的个人轻社交博客的模板主题。 模板主题特色:1......
  • 算法模板 v1.2.1.20240116
    算法模板v1.1.1.20240115:之前的历史版本已经不可寻,创建了第一份算法模板。v1.2.1.20240116:删除“编译”-“手动开栈”与“编译”-“手动开O优化”;将“编译”-“CF模板”中的第20行代码cin>>T;注释;删除“读写”及其目录下的内容;删除“图论”-“欧拉图”-“混合图”;删除“图论”-......
  • 16理解函数模板
    理解函数模板模板的意义:对函数类型可以做修改函数模板:boolcompare(Ta,Tb)模板实例化:定义一个模板参数类型,进行一次函数的实例化模板函数:一个函数模板的实例化就是一个模板函数模板类型参数:T模板非类型参数:模板的实参推演:根据实参反推模板参数类型模板的特例化:为函数......
  • 算法模板 v1.1.1
    算法模板编译CF模板#include<bits/stdc++.h>usingnamespacestd;/*====================*/#defineendl"\n"/*====================*/typedeflonglonglnt;/*====================*/voidSolve(void){}/*====================*/intmain(){#ifn......
  • thymeleaf—02—模板
    一、th:fragment模板片段我们可以使用模板,定义一些会经常复用的代码,使用th:fragment定义然后使用th:insert引入这个模板内容,或者使用th:replace进行内容替换;还有一个th:include标签也是引入模板内容,但是这个不推荐了; 除了增加模板,还可以使用th:remove进行模板的删除操作; ......
  • 蓝色时间轴个人博客网页模板代码
    看雪时间轴个人博客模板,女生唯美简洁个人博客静态页面模板,蓝色时间轴个人网页模板,下雪空间个人模板代码1、html页面代码<!doctypehtml><html><head><metacharset="gb2312"><title>看雪时间轴个人博客模板-bokequ.com</title><metaname="keywords"content="蓝色......
  • 20款最好的免费 Bootstrap 后台管理和前端模板
    20款最好的免费Bootstrap后台管理和前端模板 AdminBootstrapTemplatesFreeDownload 1.SBAdmin2Preview | Details&Download2.AdminLitePreview | Details&Download3.DirectorResponsiveAdminTemplateFreePreview | Details&Download4......
  • 产品集成过程模板
    ......