当前位置: 首页 > news >正文

旅游预定型网站建设2024年新冠第三波症状分析

旅游预定型网站建设,2024年新冠第三波症状分析,哪个网站做海外代购,网站系统建设需要什么资质CF1784D Wooden Spoon 题目大意 有2n2^n2n个人,进行nnn轮比赛。比赛的图是一棵完全二叉树。编号小的人一定能赢编号大的人,如果一个人满足: 第一次比赛被打败打败这个人的人在第二次比赛中被打败打败上一个人的人在第三次比赛中被打败…\d…

CF1784D Wooden Spoon

题目大意

2n2^n2n个人,进行nnn轮比赛。比赛的图是一棵完全二叉树。编号小的人一定能赢编号大的人,如果一个人满足:

  • 第一次比赛被打败
  • 打败这个人的人在第二次比赛中被打败
  • 打败上一个人的人在第三次比赛中被打败
  • …\dots
  • 打败上一个人的人在最后一次比赛中被打败

那么这个人就能得到安慰奖。

求对于每个人,有多少种编号的排列来比赛(叶子的排列),使得他能得安慰奖。输出答案模998244353998244353998244353


题解

我们按照题意来构建这棵二叉树,叶子节点就是这个序列,而非叶子节点的权值就是其子树中权值最大的点的权值。假如编号为kkk的点能拿安慰奖,那么这个点到根的路径上的点的权值一定是单调递减的。

假设这个点到根的权值组成的序列为a0,a1…,ana_0,a_1\dots,a_na0,a1,an,我们依次来看每个点的贡献。

aia_iai的贡献为C(2n−ai−2i−1,2i−1−1)×(2i−1)!C(2^n-a_i-2^{i-1},2^{i-1}-1)\times (2^{i-1})!C(2nai2i1,2i11)×(2i1)!。也就是说,这个点在没有kkk的那棵子树中还要放小于他的2i−1−12^{i-1}-12i11个点。因为要小于aia_iai,而且自己是一定要选的,所以要减aia_iai。又因为有kkk的那一边的点不能选,所以要减2i−12^{i-1}2i1。这棵子树内的点的顺序可以任意排列,所以要乘上(2i−1)!(2^{i-1})!(2i1)!

fi,sf_{i,s}fi,s表示第iii个数为sss时第iii个数到第nnn个数的贡献,gi,sg_{i,s}gi,s表示第iii个数小于等于sss时第iii个数到第nnn个数的贡献和。那么转移式为

fi,s=gi+1,s−1×C(2n−s−2i−1,2i−1−1)×(2i−1)!f_{i,s}=g_{i+1,s-1}\times C(2^n-s-2^{i-1},2^{i-1}-1)\times (2^{i-1})!fi,s=gi+1,s1×C(2ns2i1,2i11)×(2i1)!

gi,s=gi,s−1+fi,sg_{i,s}=g_{i,s-1}+f_{i,s}gi,s=gi,s1+fi,s

因为kkk的位置任意,所以最后还要乘上2n2^n2n。那么编号为kkk的点的答案就是g1,k−1×2ng_{1,k-1}\times 2^ng1,k1×2n

时间复杂度为O(n×2n)O(n\times 2^n)O(n×2n)

code

#include<bits/stdc++.h>
using namespace std;
const int N=1<<20;
int n;
long long jc[N+5],ny[N+5];
long long f[25][N+5],g[25][N+5];
long long mod=998244353;
long long mi(long long t,long long v){if(!v) return 1;long long re=mi(t,v/2);re=re*re%mod;if(v&1) re=re*t%mod;return re;
}
void init(){jc[0]=1;for(int i=1;i<=N;i++) jc[i]=jc[i-1]*i%mod;ny[N]=mi(jc[N],mod-2);for(int i=N-1;i>=0;i--) ny[i]=ny[i+1]*(i+1)%mod;
}
long long C(int x,int y){if(x<y) return 0;return jc[x]*ny[y]%mod*ny[x-y]%mod; 
}
int main()
{init();scanf("%d",&n);for(int s=1;s<=(1<<n);s++){f[n][s]=C((1<<n)-s-(1<<n-1),(1<<n-1)-1)*jc[1<<n-1]%mod;g[n][s]=(g[n][s-1]+f[n][s])%mod;}for(int i=n-1;i>=1;i--){for(int s=1;s<=(1<<n);s++){f[i][s]=g[i+1][s-1]*C((1<<n)-s-(1<<i-1),(1<<i-1)-1)%mod*jc[1<<i-1]%mod;g[i][s]=(g[i][s-1]+f[i][s])%mod;}}for(int s=1;s<=(1<<n);s++){printf("%lld\n",g[1][s-1]*(1<<n)%mod);}return 0;
}
http://www.yidumall.com/news/16574.html

相关文章:

  • 烟台市建委网站seo模拟点击有用吗
  • 网站开发文档总结汽车品牌推广策划方案
  • 做外贸网站那个好seo是什么东西
  • 专业做旅游网站建立自己的网站
  • 淘宝客做连接网站如何推广产品
  • 做 在线观看免费网站有哪些seo引擎优化公司
  • 白云b2b网站建设公司提高工作效率心得体会
  • 成都网站建设求职简历网站安全
  • 青岛建设网站制作百度广告联盟价格
  • 电子商务网站开发背景及意义友情链接站长平台
  • 做网站用的图片免费推广的途径与原因
  • 西安网站建设开发熊掌号惠州seo代理计费
  • 网站开发视频播放网站营口seo
  • 做网站开票内容是什么企业文化的重要性和意义
  • 邦邻营销型网站建设优化疫情防控
  • 动态网站开发 实训总结网络热词排行榜
  • 网站建设后如何放在网上信息流优化师前景
  • 北京网站建设推荐华网天下宁波seo优化项目
  • 网站生成二维码厦门网站推广公司哪家好
  • 无锡网站seo北京百度seo关键词优化
  • 手机企业网站设计百度关键词价格查询
  • 汕头cms建站模板软文广告的案例
  • 加强政协网站建设产品宣传方案
  • 长沙 网站设计 公司价格河北百度seo软件
  • 东莞网站建设 手机壳媒体营销平台
  • 赛扶做网站百度搜索引擎提交入口
  • 大庆网站建设湖北网络推广有限公司
  • wordpress邀请码插件广东优化疫情防控措施
  • 弹幕视频网站开发百度网站是什么
  • 网站建设费税率多少钱seo站长查询