T1

数位DP,太菜了打挂只有10分……

Code

//2019.1.14 12:25~12:47 PaperCloud
#include<bits/stdc++.h>
#define ll long long
using namespace std;
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<<3)+(x<<1)+ch-'0';ch=getchar();}return x*f;
}
#define mod 1000000007
#define int ll
ll B,n,m,a[100005],L[100005],R[100005],P[100005][2],S[100005][2],M[100005];
ll O,Ans=0;
int dp(int o)
{S[o+1][0]=S[o+1][1]=P[o+1][0]=P[o+1][1]=0;for(register int i=o;i;--i){P[i][1]=(P[i+1][1]+1)*a[i]%mod;P[i][0]=(P[i+1][0]+M[i+1])%mod*O%mod+(a[i]*(a[i]-1)/2%mod)*(P[i+1][1]+1)%mod;P[i][0]%=mod;S[i][1]=(S[i+1][1]+P[i][1])%mod;S[i][0]=(S[i+1][1]*a[i]%mod+S[i+1][0]*B%mod+P[i][0])%mod;}return (S[1][0]+S[1][1])%mod;
}
main()
{freopen("number.in","r",stdin);freopen("number.out","w",stdout);register int i,j;B=read();O=B*(B-1)/2;n=read();for(i=1;i<=n;++i) L[n-i+1]=read();m=read();for(j=1;j<=m;++j) R[m-j+1]=read();for(j=1;!L[j];++j) L[j]=B-1;L[j]--;if(L[j]==0&&j==n) n--;for(M[n+1]=0,M[n]=a[n]=L[n],i=n-1;i;--i) a[i]=L[i],M[i]=M[i+1]*B%mod+L[i]%mod,M[i]%=mod;Ans-=dp(n);Ans+=mod;for(M[m+1]=0,M[m]=a[m]=R[m],i=m-1;i;--i) a[i]=R[i],M[i]=M[i+1]*B%mod+R[i]%mod,M[i]%=mod;Ans+=dp(m);Ans%=mod;return 0*printf("%lld\n",Ans);
}

T2

求树上任选\(k\)个点点形成的所有虚树大小之和。答案对\(998244353\)取模

首先,如果选\(k\)个点,考虑一个点\(x\)会在几个虚树内,应该是:\(C_{n}^{k}-C_{son[i]}^{k}\),其中,\(son[i]\)表示以\(x\)为根时,一个\(x\)的子树的大小。

然后可以直接处理成类似\(ans_k=\sum a_iC_{i}^{k}\)的形式

进一步转化为\(ans_k=(k!)^{-1}\sum (i!a_i)(i-k)!^{-1}\),这可以\(NTT\)优化

Code

//2019.1.14 12:52~16:49 PaperCloud
#include<bits/stdc++.h>
#define ll long long
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
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<<3)+(x<<1)+ch-'0';ch=getchar();}return x*f;
}
#define MN 100005
#define mod 998244353
#define g 3
#define invg 332748118
struct edge{int to,nex;}e[MN<<1];
int N,en,hr[MN];
inline void ins(int f,int t)
{e[++en]=(edge){t,hr[f]};hr[f]=en;e[++en]=(edge){f,hr[t]};hr[t]=en;
}
int fac[MN],inv[MN],A[524288],B[524288],siz[MN];
inline int fpow(int x,int m){int r=1;for(;m;m>>=1,x=1ll*x*x%mod) if(m&1) r=1ll*r*x%mod;return r;}
inline int C(int m,int n){return 1ll*fac[m]*inv[n]%mod*1ll*inv[m-n]%mod;}
inline void init()
{register int i;for(i=fac[0]=1;i<=N;++i) fac[i]=1ll*fac[i-1]*i%mod;for(inv[N]=fpow(fac[N],mod-2),i=N-1;~i;--i) inv[i]=1ll*inv[i+1]*(i+1)%mod;
}
int cnt=0;
inline void dfs(int x=1,int f=0)
{register int i;siz[x]=1;for(i=hr[x];i;i=e[i].nex)if(e[i].to^f) dfs(e[i].to,x),siz[x]+=siz[e[i].to],A[siz[e[i].to]]--;A[N-siz[x]]--;
}
int M,di,pos[524288],invM;inline void NTT(int *a,int type)
{register int i,j,p,k;for(i=0;i<M;++i)if(i<pos[i]) std::swap(a[i],a[pos[i]]);for(i=1;i<M;i<<=1){ll wn=fpow(type>0?g:invg,(mod-1)/(i<<1));for(p=i<<1,j=0;j<M;j+=p) {ll w=1;for(k=0;k<i;++k,w=w*wn%mod){ll X=a[j+k],Y=w*a[j+i+k]%mod;a[j+k]=(X+Y)%mod;a[j+i+k]=(X-Y+mod)%mod;}}}if(type==-1) for(i=0;i<M;++i) a[i]=1ll*a[i]*invM%mod;
}
int main()
{freopen("tree.in","r",stdin);freopen("tree.out","w",stdout);N=read();register int i,x;for(i=1;i<N;++i) x=read(),ins(x,read());init();dfs();for(i=1;i< N;++i) A[i]=(A[i]+mod)%mod;A[N]=N;for(i=1;i<=N;++i) A[i]=1ll*A[i]*fac[i]%mod;for(i=0;i<=N;++i) B[i]=inv[N-i];A[0]=0;for(M=1,di=0;M<=N<<1;M<<=1,di++);invM=fpow(M,mod-2);for(i=0;i<M;++i) pos[i]=(pos[i>>1]>>1)|((i&1)<<(di-1));NTT(A,1);NTT(B,1);for(i=0;i<M;++i) A[i]=1ll*A[i]*B[i]%mod;NTT(A,-1);for(i=1;i<=N;++i)printf("%d\n",(1ll*A[N+i]*inv[i])%mod);return 0;
}

Blog来自PaperCloud,未经允许,请勿转载,TKS!

转载于:https://www.cnblogs.com/PaperCloud/p/10268705.html

[20190113]四校联考相关推荐

  1. NOIP模拟赛 四校联考 递推 + 分类讨论 + 树上期望

    NOIP 模拟题 题目名称兔子被子蚊子 源程序文件名rabbit.cpp quilt.cpp mosquito.cpp 输入文件名rabbit.in quilt.in mosquito.in 输出文件 ...

  2. [四校联考P3] 区间颜色众数 (主席树)

    主席树 Description 给定一个长度为 N 颜色序列A,有M个询问:每次询问一个区间里是否有一种颜色的数量超过了区间的一半,并指出是哪种颜色. Input 输入文件第一行有两个整数:N和C 输 ...

  3. [4.9福建四校联考]

    来自FallDream的博客,未经允许,请勿转载 奇怪的O(n)大赛,三道题数据都是几百万,真吓人. ------------------------------------------------- ...

  4. 2017-3-19四校联考

    T1输出0有20分结果我输出1爆0(题目说精度差为整数有40%的分数,结果告诉我只能差0.5--),T2打了20分暴力,T3交了个感觉能拿50分的结果是正解--被卡常了一个点,总分110/300 T1 ...

  5. 2/19 福建四校联考

    1.设计图案 给你一个n*m的矩阵,每个格子必须填或者不能填,要用环和1*2的小方块填满它,求方案数. 比如3*2,每个格子都必须填 有6种填法. n*m<=300 当时一看就觉得不可做然后就放 ...

  6. [20180826]四校联考

    T1谜题(nazo) Problem Here Solution 先把所有点的开关状态压成一个二进制数 按一个按钮就相当于异或上一个二进制数 显然不会按同一个按钮两次 枚举\(\left\lfloor ...

  7. [20180812]四校联考

    T1 消失的无向图(missing) 题目描述 从前有一张n个点的无向图,边权都是正整数.但现在所有的边都消失了,只留下任意两点之间的最短路. 你现在想知道,所有边的边权和至少是多少. ​ 输入格式 ...

  8. [20180819]四校联考

    不要问我8.19的题为什么今天才写完,因为我弱啊 T1 扫雷(mine) Problem戳这里 Solution: 显然,\(ans = min_{i=1}^n \frac{bi}{ai}\),令cn ...

  9. 4246. 【五校联考6day2】san (Standard IO)

    4246. [五校联考6day2]san (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed Limits D ...

最新文章

  1. Spring Boot 工程集成全局唯一ID生成器 Vesta
  2. 2018 东北地区大学生程序设计竞赛(ABEHIK)
  3. matlab求传递函数在某个频率点的增益_【干货分享】轻松弄懂开关电源TL431环路补偿传递函数推导...
  4. GridView中使用DataFromatString
  5. ECMAScript 6 入门
  6. CSDNmarkdown编辑器直接写代码的小效果(一生愿)
  7. SAP后台执行大数据量报表(鹦鹉学舌篇)
  8. 下载量过百万的吴恩达机器学习和深度学习笔记更新了!(附PDF下载)
  9. boost::detail::yield相关的测试程序
  10. 一个easyui的案例(SSH)
  11. Java之杨辉三角的实现
  12. 1.3Python快速入门
  13. Centos系统python2.x升级python3.x
  14. 算法设计 - LCS 最长公共子序列最长公共子串 LIS 最长递增子序列
  15. 杂文笔记《“去QE”时代下,QE如何破茧重生》
  16. linq 清除一条数据中的某个字段值_利用Postman中Tests断言校验返回结果
  17. ora-01017:invalid username/password
  18. Tensorflow 中文语音识别
  19. 若依分离版整合IJpay实现第三方支付-(微信支付篇_v2)
  20. 28岁学Java晚不晚?快30学java还来得及吗?

热门文章

  1. 不会画饼的领导,不值得托付
  2. 人工智能在医疗行业应用面临的五大挑战
  3. 2020 年技术趋势一览:AutoML、联邦学习、云寡头时代的终结
  4. 2019年上半年收集到的人工智能迁移学习干货文章
  5. 强化学习应用于组合优化问题
  6. 这12大管理原则,经营者必知
  7. 头条丨2017年人工智能年报
  8. 梦境交互:做个现代灵媒,考虑一下?
  9. SpaceX再发射58颗星链卫星 总数达到538颗
  10. 刘锋 吕乃基:互联网中心化与去中心化之争