瞬间移动

题意

三维空间中从 \((0,0,0)\) 开始,每次移动 1,问刚好走 \(N\) 次能到 \((X,Y,Z)\) 的方案数

\(N\le10^7\),答案模 \(998244353\)

Sol

一个感觉很简单的题,结果。。。

不失一般性地,设 \(x,y,z\ge0\)

显然当 \(x+y+z>n\) 或 \((n-x-y-z)\mod2=1\) 时答案为 0

先只考虑前两维,设 \(F_k\) 为从 \((0,0)\) 一共走 \(X+Y+2k\) 步到 \((X,Y)\) 的方案数

\[\begin{aligned}
F_k &= \sum_{i=0}^k
\begin{pmatrix} x+y+2k \\ x+i\quad i\quad y+k-i\quad k-i \end{pmatrix} \\
&= \sum_{i=0}^k \begin{pmatrix} x+y+2k \\ x+y+k \end{pmatrix}
\begin{pmatrix} x+y+k \\ y+k-i \end{pmatrix}\begin{pmatrix} k \\ i \end{pmatrix} \\
&= \begin{pmatrix} x+y+2k \\ x+y+k \end{pmatrix}\sum_{i=0}^k
\begin{pmatrix} x+y+k \\ y+k-i \end{pmatrix}\begin{pmatrix} k \\ i \end{pmatrix} \\
&= \begin{pmatrix} x+y+2k \\ x+y+k \end{pmatrix}
\begin{pmatrix} x+y+2k \\ y+k \end{pmatrix}
\end{aligned}
\]

解释

首先:

\[\begin{pmatrix} n\\ a\quad b\quad c \quad d \end{pmatrix}
= \begin{pmatrix} n\\a \end{pmatrix}\begin{pmatrix} n-a\\b \end{pmatrix}
\begin{pmatrix} n-a-b\\c \end{pmatrix}\begin{pmatrix} n-a-b-c\\d \end{pmatrix}
\]

先后顺序可以交换


其次:

\[\begin{pmatrix} n \\ m \end{pmatrix}\begin{pmatrix} n-m \\ r \end{pmatrix}
= \begin{pmatrix} n \\ m+r \end{pmatrix}\begin{pmatrix} m+r \\ r \end{pmatrix}
= \begin{pmatrix} n \\ m+r \end{pmatrix}\begin{pmatrix} m+r \\ m \end{pmatrix}
\]

从 \(n\) 个里面分别选出 \(m,r\) 个的方案数

等同于

先从 \(n\) 里面选出 \(m+r\) 个,其中再选出 \(m\) 或 \(r\) 个的方案


  1. 第一个式子可以化成 \(\begin{pmatrix} x+y+2k \\ x+i\quad y+k-i\end{pmatrix}\begin{pmatrix} k \\ i\quad k-i \end{pmatrix}\)

    前面那一部分化成 \(\begin{pmatrix} x+y+2k \\ x+y+k \end{pmatrix}
    \begin{pmatrix} x+y+k \\ y+k-i \end{pmatrix}\)

    后面化成 \(\begin{pmatrix} k \\ i \end{pmatrix}\) ,可得第二个式子。

  2. 第二个式子提出与 \(i\) 无关项得到第三个式子

  3. 第三个式子的 \(\sum_{i=0}^k
    \begin{pmatrix} x+y+k \\ y+k-i \end{pmatrix}\begin{pmatrix} k \\ i \end{pmatrix}\)

    其实就是从 \(x+y+2k\) 个球中选 \(y+k\) 个,枚举最后 \(k\) 个中选了多少个

    即 \(\begin{pmatrix} x+y+2k \\ y+k \end{pmatrix}\)

到三维

直接枚举 \(z\) 走的步数即可,复杂度 \(O(n)\)

Code

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
const LL P = 998244353;
const int N = 1e7 + 5;
inline LL Pow(LL x, LL y) {
register LL res = 1;
for (; y; y >>= 1, x = x * x % P)
if (y & 1) res = res * x % P;
return res;
}
LL fac[N], inv[N], res;
inline LL C(int n, int m) {
if (m > n) return 0;
return fac[n] * inv[m] % P * inv[n - m] % P;
}
int n, X, Y, Z, le, tt;
inline LL count(int k) {
return C(X + Y + 2 * k, X + Y + k) * C(X + Y + 2 * k, Y + k) % P;
}
int main() {
// freopen("teleport.in", "r", stdin);
// freopen("teleport.out", "w", stdout);
scanf("%d%d%d%d", &n, &X, &Y, &Z);
X = abs(X), Y = abs(Y), Z = abs(Z), le = X + Y + Z, fac[0] = 1;
if (n < le) return puts("0"), 0;
if ((n - le) & 1) return puts("0"), 0; for (int i = 1; i <= n; i++) fac[i] = fac[i - 1] * i % P;
inv[n] = Pow(fac[n], P - 2);
for (int i = n - 1; ~i; i--) inv[i] = inv[i + 1] * (i + 1) % P;
tt = (n - le) / 2;
for (int z = 0; z <= tt; z++)
(res += C(n, z) * C(n - z, Z + z) % P * count(tt - z) % P) %= P;
printf("%lld", res);
}

总结

这个式子就是经典的范德蒙德卷积。

高级的名字,本质是组合数的变换

以后遇到这种题要记得各种性质,大胆去推

DYOJ 【20220317模拟赛】瞬间移动 题解的更多相关文章

  1. 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解

    今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...

  2. 2020.3.23 模拟赛游记 & 题解

    这次的模拟赛,实在是水. 数据水,\(\texttt{std}\) 水,出题人水,做题人也水.??? 游记就说一句: 水. T1 metro 弱智题. 人均 \(100pts\). #pragma G ...

  3. 洛谷[LnOI2019]长脖子鹿省选模拟赛 简要题解

    传送门 听说比赛的时候T4T4T4标程锅了??? WTF换我时间我要写T3啊 于是在T4T4T4调半天无果的情况下260pts260pts260pts收场真的是tcltcltcl. T1 快速多项式变 ...

  4. NOIP模拟赛10 题解

    t3: 题意 给你一棵树,然后每次两种操作:1.给一个节点染色 : 2. 查询一个节点与任意已染色节点 lca 的权值的最大值 分析 考虑一个节点被染色后的影响:令它的所有祖先节点(包括自身)的所有除 ...

  5. BJOI 模拟赛 #3 题解

    T1 一个网格,每个点有权值,求有多少条路径权值乘积不小于 $n$ $R,C \leq 300, n \leq 10^6$ sol: 暴力 dp 是 $O(R \times C \times n)$ ...

  6. BJOI 2019 模拟赛 #2 题解

    T1 完美塔防 有一些空地,一些障碍,一些炮台,一些反射镜 障碍会挡住炮台的炮, 反射镜可以 90° 反射炮台的光线,炮台可以选择打他所在的水平一条线或者竖直一条线 求是否有一组方案满足每个空地必须要 ...

  7. 【CYH-02】noip2018数论模拟赛:赛后题解

    1.小奔的矩阵 2.大奔的方案 3.小奔与不等四边形 4.小奔的方案 当然本次比赛肯定难度不会仅限于此啦!后续还会--

  8. bsoj5988 [Achen模拟赛]期望 题解

    bsoj5988 Description [题目背景] NOI2018 已经过去了许久,2019 届的 BSOIer 们退役的退役,颓废的颓废,计数能力大不如前.曾经的数数之王 xxyj 坦言:&qu ...

  9. contesthunter暑假NOIP模拟赛第一场题解

    contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...

随机推荐

  1. 不用关闭重启cad及不用更改快捷方式或者版本号c#调试cad插件

    c#开发的cad插件需要重启cad才能进行调试,然而高版本的cad启动比较慢特别是一些古董电脑,而且cad有重启次数限制.针对不用重启cad调试已经有成熟的方案了,但是需要调试一次修改一次快捷方式或者 ...

  2. C++ functional库中的仿函数

    一.仿函数简介 仿函数(functor)又称之为函数对象(function object),实际上就是 重载了()操作符 的 struct或class. 由于重载了()操作符,所以使用他的时候就像在调 ...

  3. k8s TLS bootstrap解析-k8s TLS bootstrap流程分析

    当k8s集群开启了TLS认证后,每个节点的kubelet组件都要使用由kube-apiserver的CA签发的有效证书才能与kube-apiserver通信:当节点非常多的时候,为每个节点都单独签署证 ...

  4. Python Pandas库 初步使用

    用pandas+numpy读取UCI iris数据集中鸢尾花的萼片.花瓣长度数据,进行数据清理,去重,排序,并求出和.累积和.均值.标准差.方差.最大值.最小值

  5. mysql的半同步复制

    1. binlog dump线程何时向从库发送binlog mysql在server层进行了组提交之后,为了提高并行度,将提交阶段分为了 flush sync commit三个阶段,根据sync_bi ...

  6. Ubuntu 百度飞桨和 CUDA 的安装

    Ubuntu 百度飞桨 和 CUDA 的安装 1.简介 本文主要是 Ubuntu 百度飞桨 和 CUDA 的安装 系统:Ubuntu 20.04 百度飞桨:2.2 为例 2.百度飞桨安装 访问百度飞桨 ...

  7. 《手把手教你》系列基础篇(九十)-java+ selenium自动化测试-框架设计基础-Logback实现日志输出-中篇(详解教程)

    1.简介 上一篇宏哥介绍是如何使用logback将日志输出到控制台中,但是如果需要发给相关人需要你拷贝出来,有时候由于控制台窗口的限制,有部分日志将会无法查看,因此我们还是需要将日志输出到文件中,因此 ...

  8. Luffy /2/ 后台数据库配置&前台创建配置

    目录 二次封装Response 后台数据库配置 命令操作 pycharm连接 django操作mysql 方式一 方式二 user表设计 前台创建及配置 全局css样式配置 配置文件配置 二次封装Re ...

  9. Linux下快速拷贝单个大文件的秘诀

    #include <stdio.h> #include <unistd.h> #include <fcntl.h> #include <stdlib.h> ...

  10. vue动态路由实现原理 addRoute

    vue新版router.addRoute基础用法 新版Vue Router中用router.addRoute来替代原有的router.addRoutes来动态添加路由.子路由 在添加子路由的时候 比如 ...