原文链接https://www.cnblogs.com/zhouzhendong/p/ARD102E.html

题目传送门 - ARC102E

题意

  有 $n$ 个取值为 $[1,k]$ 的骰子,对于每一个 $i(i\in [2,2k])$ ,输出满足“任意两个骰子的值的和不为 $i$ ”的情况总数。

  $1\leq n,k\leq 2000$

题解

  扯淡还是要先撤的。比赛的时候被 D 题续了好久, E 题差一句话就调出来了。如果赛后与 Functionendless 交流完 D 题,回来检查这题,然后检查了 2 分钟就发现了错误…… QAQ

  首先考虑求解其中一个 $i$:

  如果 $i$ 为 奇数 : 那么,显然,对于所有 $x(x\leq \frac{i-1}2)$  , $i-x\neq x$ ,且所有骰子的取值中只可能出现 $x$ 或者 $i-x$ ,当然也有可能两种都不出现,我们称这样的一对数为一对“互斥数对”。显然知道 $i$ 和 $k$ 之后,互斥数对的种数很容易知道,设为 $lim$ 。于是我们枚举一下选择几个互斥数对,假设我们选择了 $j$ 种互斥数对:那么,首先是在所有的互斥数对里选择 $j$ 个数对,方案数为 $\binom{lim}{j}$;然后,对于每一种出现的互斥数对,都可以选择其中一种数让他出现,故有 $2^j$ 种,这样子相当于已经至少选择了 $j$ 个数,故我们还要放 $n-j$ 个数字,我们有 $k-lim+j$ 种数字可供任意选择。于是问题被转化成了在 $k-lim+j$ 个带标号的位置放上非负整数,使得所有位置的数之和为 $n-j$ 的方案数。这个东西直接用 插板法 搞成组合数就可以了。

  如果 $i$ 为 偶数 :那么显然出现了一种特殊情况: $2x=i$ ,于是 $x$ 这个数最多只能出现。于是我们直接分这个数字出现和不出现两种情况,问题就被转化成了两个 $i$ 为奇数时的问题了。详见代码。

  通过预处理组合数和预处理 $2$ 的幂,我们可以在大约 $O(n^2+nk)$ 的时间复杂度内通过此题。

代码

#include <bits/stdc++.h>
using namespace std;
const int N=4005,mod=998244353;
int n,k,C[N][N],pw2[N];
int c(int n,int m){
if (m>n||m<0)
return 0;
return C[n][m];
}
int calc(int m,int n){return c(n+m-1,m-1);}
int Get(int v,int n,int k){
int ans=0;
int lim=max(0,v/2-max(0,v-1-k));
for (int i=0;i<=lim;i++)
ans=(1LL*pw2[i]*C[lim][i]%mod*calc(k-lim*2+i,n-i)+ans)%mod;
return ans;
}
int main(){
pw2[0]=1;
for (int i=1;i<N;i++)
pw2[i]=pw2[i-1]*2%mod;
for (int i=0;i<N;i++)
C[i][0]=C[i][i]=1;
for (int i=1;i<N;i++)
for (int j=1;j<i;j++)
C[i][j]=(C[i-1][j-1]+C[i-1][j])%mod;
scanf("%d%d",&k,&n);
for (int i=2;i<=2*k;i++)
if (i&1)
printf("%d\n",Get(i,n,k));
else
printf("%d\n",(Get(i-1,n,k-1)+Get(i-1,n-1,k-1))%mod);
return 0;
}

  

AtCoder Regular Contest 102 (ARC102) E - Stop. Otherwise... 排列组合的更多相关文章

  1. AtCoder Regular Contest 102 (ARC102) D All Your Paths are Different Lengths 构造

    原文链接https://www.cnblogs.com/zhouzhendong/p/ARC102D.html 题目传送门 - ARC102D 题意 给定 $L$,请你构造一个节点个数为 $n$ ,边 ...

  2. AtCoder Regular Contest 102

    AtCoder Regular Contest 102 C - Triangular Relationship 题意: 给出n,k求有多少个不大于n的三元组,使其中两两数字的和都是k的倍数,数字可以重 ...

  3. AtCoder Regular Contest 102 E Stop. Otherwise...

    题目链接:atcoder 大意:有\(n\)个骰子,每个骰子上面有\(k\)个数,分别是\(1\text ~ k\),现在求\(\forall i\in[2...2k]\),求出有多少种骰子点数的组合 ...

  4. AtCoder Regular Contest 102 D - All Your Paths are Different Lengths

    D - All Your Paths are Different Lengths 思路: 二进制构造 首先找到最大的t,使得2^t <= l 然后我们就能构造一种方法使得正好存在 0 到 2^t ...

  5. 2018.09.02 Atcoder Regular Contest 102简要题解

    比赛传送门 T1 Triangular Relationship 分析之后发现有两种情况: 1. n为奇数,那么所有数都是k的倍数. 2. n为偶数,那么所有数都是k/2的倍数. 然后就可以愉快A题了 ...

  6. AtCoder Regular Contest 061

    AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...

  7. AtCoder Regular Contest 094 (ARC094) CDE题解

    原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...

  8. AtCoder Regular Contest 092

    AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...

  9. AtCoder Regular Contest 093

    AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...

随机推荐

  1. 接口签名进行key排序,并MD5加密

    import org.apache.commons.codec.digest.DigestUtils; import java.io.UnsupportedEncodingException; imp ...

  2. layui 常见的表单元素

    第一步:引用文件 效果图(日期.文件上传在下面): <form class="layui-form" action=""> <div clas ...

  3. 面向对象(metaclass继承高级用法)

    方法一:# class MyType(type):# def __init__(self,*args,**kwargs):# print('132')# super(MyType,self).__in ...

  4. JavaScript自定义对象

    一,概述 在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 目前在Javascrip ...

  5. js---json对象拆分

    var a={ "bb":"world", "a0":1, "a1":2, "b0":4, &quo ...

  6. mysql中的sql

    变量 用户变量: 在用户变量前加@ 系统变量: 在系统变量前加@@ 运算符 算术运算符有: +(加), -(减), * (乘), / (除) 和% (求模) 五中运算 位运算符有: & (位于 ...

  7. 用来表达更复杂的sql语句!!!!!extra 原声sql

    extra 用来表达更复杂的sql语句!!!!! extra可以指定一个或多个 参数,例如 select, where or tables. 这些参数都不是必须的,但是你至少要使用一个!要注意这些额外 ...

  8. selenium 操作复选框

    场景 从上一节的例子中可以看出,webdriver可以很方便的使用findElement方法来定位某个特定的对象,不过有时候我们却需要定位一组对象, 这时候就需要使用findElements方法. 定 ...

  9. unzip文件解压

    1.记录下,遇到.zip的安装包,指定解压到某个地方 格式:unzip      压缩包名.zip  -d   存放路径  

  10. POJ 3080 Blue Jeans (字符串处理暴力枚举)

    Blue Jeans  Time Limit: 1000MS        Memory Limit: 65536K Total Submissions: 21078        Accepted: ...