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

旅游预定型网站建设选择一个产品做营销方案

旅游预定型网站建设,选择一个产品做营销方案,商城网站建设平台,大坪网站建设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.zhongyajixie.com/news/51826.html

相关文章:

  • 公司主页网站制作微营销推广平台有哪些
  • 哪个网站做h5好用网页设计用什么软件
  • 在什么网站做兼职大数据分析网站
  • 网站制作 用户登录系统永久观看不收费的直播
  • wordpress 设成中文seo关键词排名优化的方法
  • 网站自动登录怎么做怎样进行seo
  • 网站建设的基本流程seo推广视频隐迅推专业
  • 网站图片调用哈尔滨网络推广
  • 网站网页怎么做武安百度seo
  • pdf 网站建设百度代理授权查询
  • 做网站哪个公司好电商怎么推广自己的产品
  • 有没有专门做兼职的网站上海站优云网络科技有限公司
  • 邢台无忧网站建设公司如何点击优化神马关键词排名
  • 做网站注册商标郑州网站推广方案
  • 静态网站生成器怎样做厦门网络推广
  • 盗版小说网站怎么做的湖南做网站的公司
  • 洛阳做网站公司最打动人心的广告语
  • 如何虚拟一个公司网站班级优化大师免费下载学生版
  • 公司的网站建设费会计分录搭建网站平台
  • 太原网站排名公司哪家好搜索优化的培训免费咨询
  • 网站导航如何优化seo网站关键词优化
  • 怎么做asp网站公司的seo是什么意思
  • 商城类网站建设多少钱怎么做网络广告
  • 养殖推广网站怎么做新站优化案例
  • 群晖做网站域名重庆森林
  • 简单的做网站软件有啥外贸平台排名
  • 招网站建设销售免费网站制作成品
  • 互联网企业有哪些行业黄山seo
  • 高中网站制作蜂蜜网络营销推广方案
  • 临沂seo网站推广百度广告上的商家可靠吗