首页 > 其他分享 >CSP模拟13

CSP模拟13

时间:2023-08-06 20:34:00浏览次数:39  
标签:dis1 13 return rs int ans CSP 模拟 dis

T1考场降智,写了个假的模拟,没签上到。T3空间爆了,直接CE(应该是线段树写挂了).


y

xt在四个角,取最大值,排序.

Code
    for(int i=1;i<=n;i++){
        for(int j=1;j<=m;j++){
            a[++tot]=max({calc(1,1,i,j),calc(i,j,1,m),calc(i,j,n,1),calc(i,j,n,m)});
        }
    }

    sort(a+1,a+1+tot,cmp);

    for(int i=1;i<=n*m;i++){
        printf("%d ",a[i]);
    }

S

神奇的转化.
$ num= \Sigma _{i=1} ^{n} (k>=i) $ num即大于等于k的数.对于每一个k进行求解.我们现在只关心与k的大小关系不在乎具体数.我们把>=k的看作1,< k 的看做0.最后统计ret为1的方案数 *i!(n-i)!(数不确定).已经是第3次见到这个技巧了,其他两次都是数据结构middle,排序都是求跟中位数差不多的东西.放在DP还是挺妙的.

要滚数组.

Code
signed main(){
    // freopen("in","r",stdin);

    n=read();

    for(int i=1;i<=n-1;i++)
        s[i]=read();
    
    fac[0]=1;
    for(int i=1;i<=n;i++)
        fac[i]=fac[i-1]%mod*i%mod;

    dp[1][0][0]=1;
    dp[1][1][1]=1;
    int now=0;

    for(int i=2;i<=n;i++){
        memset(dp[now],0,sizeof(dp[now]));
        for(int j=0;j<=n;j++){
            if(s[i-1]==0){
                dp[now][j][0]=(dp[now][j][0]+dp[now^1][j][1]+dp[now^1][j][0])%mod;
                
                if(j){
                    dp[now][j][1]=(dp[now][j][1]+dp[now^1][j-1][1])%mod;
                    dp[now][j][0]=(dp[now][j][0]+dp[now^1][j-1][0])%mod;
                }
            }else{
                if(j){
                    dp[now][j][1]=(dp[now][j][1]+dp[now^1][j-1][1]+dp[now^1][j-1][0])%mod;
                }
                dp[now][j][1]=(dp[now][j][1]+dp[now^1][j][1])%mod;
                dp[now][j][0]=(dp[now][j][0]+dp[now^1][j][0])%mod;
            }
        }
        now^=1;
    }

    int ans=0;

    for(int i=1;i<=n;i++){
        ans=(ans+dp[now^1][n-i+1][1]%mod*fac[i-1]%mod*fac[n-i+1]%mod)%mod;
    }

    printf("%lld ",ans%mod);

    return 0;
}


p

结论:对于两个点集$ S,T $ 设他们直径端点的集合为 $ f(S),f(T) $ 那么有 $ f(S \cup T) \subset (f(S) \cup f(T)) $

最大距离其实就是直径,直接线段树维护直径的两个端点.

Code
#include<cstdio>
#include<iostream>

#define lc (k<<1)
#define rc (k<<1|1)

using namespace std;
const int N=1e5+5;

inline int read(){
    int x=0,f=1;
    char ch=getchar();

    while(ch<'0'||ch>'9'){
        if(ch=='-')
            f=-1;
        ch=getchar();
    }
    while(ch>='0'&&ch<='9'){
        x=(x<<1)+(x<<3)+(ch^48);
        ch=getchar();
    }
    return x*f;
}

struct Node{
    int to,next;
}e[N<<1];
int lk[N],ntot;

void add(int x,int y){
    e[++ntot]=(Node){y,lk[x]};
    lk[x]=ntot;
}

int n,m;

int dep[N],top[N],son[N],f[N],siz[N];

int dfs1(int x,int fa){
	f[x]=fa;dep[x]=dep[fa]+1;
	siz[x]=1;

	for(int i=lk[x];i;i=e[i].next){
		int y=e[i].to;

		if(y==fa)
			continue;
		siz[x]+=dfs1(y,x);
		
		if(siz[y]>siz[son[x]])
			son[x]=y;
	}
	return siz[x];
}
void dfs2(int x,int t){
	top[x]=t;
	
	if(son[x])
		dfs2(son[x],t);

	for(int i=lk[x];i;i=e[i].next){
		int y=e[i].to;
		if(y==f[x]||y==son[x])
            continue;
		dfs2(y,y);
	 } 
}

int get_lca(int x,int y){
	while(top[x]!=top[y]){
		if(dep[top[x]]<dep[top[y]])
			swap(x,y);
		x=f[top[x]];
	}
	if(dep[x]>dep[y])
		swap(x,y);
	return x;
}
int get_dis(int x,int y){
    if(!(x+y))  
        return -1;
    if(!x||!y)
        return 0;
    return dep[x]+dep[y]-(dep[get_lca(x,y)]*2);
}

struct Tree{
    int l,r;
}t[N<<2];

Tree push_up(Tree ls,Tree rs){
    Tree ans={0,0};    
    int dis=0,dis1=0;

    dis=get_dis(ls.l,ls.r);
    ans=ls;

    dis1=get_dis(rs.l,rs.r);
    if(dis1>dis)
        dis=dis1,ans=rs;
    dis1=get_dis(ls.l,rs.l);
    if(dis1>dis){
        dis=dis1;
        ans.l=ls.l,ans.r=rs.l;
    }
    dis1=get_dis(ls.l,rs.r);
    if(dis1>dis){
        dis=dis1;
        ans.l=ls.l,ans.r=rs.r;
    }
    dis1=get_dis(ls.r,rs.l);
    if(dis1>dis){
        dis=dis1;
        ans.l=ls.r,ans.r=rs.l;
    }
    dis1=get_dis(ls.r,rs.r);
    if(dis1>dis){
        dis=dis1;
        ans.l=ls.r,ans.r=rs.r;
    }
    return ans;
}

void update(int k,int l,int r,int pos){
    if(l==r){
        if(!t[k].l)
            t[k].l=t[k].r=l;
        else
            t[k].l=t[k].r=0;
        return ;
    }

    int mid=(l+r)>>1;

    if(pos<=mid)
        update(lc,l,mid,pos);
    else
        update(rc,mid+1,r,pos);
    t[k]=push_up(t[lc],t[rc]);
}

Tree query(int k,int l,int r,int L,int R){
    if(L<=l&&r<=R)
        return t[k];
    
    int mid=(l+r)>>1;
    Tree ans1={0,0},ans2={0,0};

    if(L<=mid)
        ans1=query(lc,l,mid,L,R);
    if(R>mid)
        ans2=query(rc,mid+1,r,L,R);
    return push_up(ans1,ans2);
}

int main(){
    // freopen("in","r",stdin);

    n=read(),m=read();

    for(int i=1;i<=n-1;i++){
        int x=read(),y=read();
        add(x,y),add(y,x);
    }

    dfs1(1,0);dfs2(1,1);
    // printf("%d",get_lca(2,4));
    while(m--){
        int opt=read();

        if(opt==1){
            int x=read();
            update(1,1,n,x);
        }else{
            int l=read(),r=read();
            Tree ans=query(1,1,n,l,r);
            printf("%d\n",get_dis(ans.l,ans.r));
        }
    }

    return 0;
}

m

AT_arc096_c

题解

oj卡常.

标签:dis1,13,return,rs,int,ans,CSP,模拟,dis
From: https://www.cnblogs.com/yszy/p/17609783.html

相关文章

  • 模拟退火
    模拟退火(SimulateAnneal)是一种用于解决问题方案数极大且非单峰函数的随机化算法,原理与金属退火类似。每次随机出一个新解,若新解更优则接受,否则以一个与温度和与最优解的差相关的概率接受它。降温模拟退火有三个参数:初始温度\(T_0\),降温系数\(\Delta\),终止温度\(T_k\).其中......
  • ABC313
    D-OddorEven假设\(A_1\)到\(A_{k-1}\)的和是偶数。那么通过\(n\)次询问可以得到所有数是\(0\)还是\(1\)。如果将\(A_1\)到\(A_{k-1}\)代入检验发现和不是偶数,由于\(k\)是奇数,反转所有数,可以使它合法。#include<bits/stdc++.h>usingnamespacestd;consti......
  • 模拟赛记录
    ZROI暑假集训T1给定序列\(a_i\)和\(d\),找出最长的子区间使得区间内元素排序后相差不超过\(d\)。人类智慧题两个限制:编号连续和差值的限制,两个分开维护都好做,但是结合起来比较麻烦,考虑每次把区间按照其中一个限制处理得到若干小区间,再把这些小区间按另一个限制处理,直到得......
  • AtCoder Beginner Contest (ABC) 313 D-E
    Tasks-AtCoderBeginnerContest313PS:当时看到D过的比E多就一直在考虑D,但还没做出来,其实个人感觉E比D简单。 D-OddorEven交互题。有n个数,最多可以询问n次然后要求判断出这n个数的奇偶性。每次可以询问数组里任意k个元素的和是不是奇数一开始想到的是高斯消元,n次总能......
  • 一、Flink-1.13.6源码编译运行
    1、概述本节演示如何在本地编译、运行Flink源码。技术有限,欢迎各位大佬在评论区批评指正。2、版本说明名称版本flink1.13.6jdk1.8Maven3.2.5操作系统Mac3、编译Flink源码1)从github下载Flink源码gitclonehttps://github.com/apache/flink......
  • AtCoder Beginner Contest 313 A-E Code
    比赛链接:AtCoderBeginnerContest313-AtCoder A:#include<bits/stdc++.h>usingnamespacestd;intmain(){cin.tie(0);ios::sync_with_stdio(false);intn;cin>>n;intp1;cin>>p1;intma......
  • 前端学习笔记202307学习笔记第六十一天-react知识点串讲之13
        ......
  • 前端学习笔记202307学习笔记第六十一天-模拟实现拦截器功能3
    前端        ......
  • 前端学习笔记202307学习笔记第六十一天-模拟实现拦截器功能2
       ......
  • 前端学习笔记202307学习笔记第六十一天-模拟实现拦截器功能1
      ......