首页 > 其他分享 >题解 校内考20230104 T2 旗木双翼

题解 校内考20230104 T2 旗木双翼

时间:2023-01-04 21:46:32浏览次数:51  
标签:ch 落子 格子 题解 T2 旗木 序列 棋子 Itachi

题目描述

菲菲和牛牛在一块 \(n\) 行 \(m\) 列的棋盘上下棋,菲菲执黑棋先手,牛牛执白棋后手。

棋局开始时,棋盘上没有任何棋子,两人轮流在格子上落子,直到填满棋盘时结束。落子的规则是:一个格子可以落子当且仅当这个格子内没有棋子且这个格子的左侧及上方的所有格子内都有棋子。

Itachi 听说有不少学弟在省选现场 AC了 D1T1,解决了菲菲和牛牛的问题,但是 Itachi 听说有的人认为复杂度玄学,Itachi 并不想难为学弟学妹,他想为大家节约时间做剩下的题,所以将简化版的 D1T1带给大家。

Itachi 也在一块 \(n\) 行 \(m\) 列的棋盘上下棋,不幸的是 Itachi 只有黑棋,不过幸好只有他一个人玩。现在,Itachi 想知道,一共有多少种可能的棋局(不考虑落子顺序,只考虑棋子位置)。

Itachi 也不会为难学弟学妹们去写高精度,所以只需要告诉 Itachi 答案 \(\bmod 998244353\)(一个质数)的结果。

思路

由于一个格子可以落子当且仅当这个格子内没有棋子且这个格子的左侧及上方的所有格子内都有棋子,则作为一种结果,其从上到下每行的棋子个数是不严格单调递减的,如下图:

按行分析,只考虑每行的棋子个数,得到一个不严格单调递减序列,由于序列长度和范围固定,则考虑排列组合。但排列组合选的数各不相同,于是要想办法将其变成一个严格单调递减序列且不影响结果。

将最后一行加上 \(1\) 个棋子,倒数第二行加上 \(2\) 个棋子...第一行加上 \(n\) 个棋子,于是得到了下图:

这样一来,原先的序列 \(5,3,3,2\) 变成了现在的序列 \(9,7,5,3\) 成了严格单调笛剑序列且与前面的序列一一对应,则达到了先前的目的,可以进行排列组合。 考虑到第一行最多可以有 \(n+m\) 列,最后一行最少可以有 \(1\) 列(原本可以没有,加上了一个棋子),则问题就转化成了在 \([1,n+m]\) 范围内,任选 \(n\) 个数(一共有 \(n\) 行),有多少种结果。很明显,答案就是 \(C_{n+m}^n\) 。最后,由于 \(n,m\) 较大,且题目在疯狂暗示 \(9982443353\) 是个质数,所以要求逆元。

CODE

#include <bits/stdc++.h>
typedef long long ll;
using namespace std;
template<typename T>inline T read(){
    T a=0;bool s=0;
    char ch=getchar();
    while(ch>'9' || ch<'0'){
        if(ch=='-')s^=1;
        ch=getchar();
    }
    while(ch>='0' && ch<='9'){
        a=(a<<3)+(a<<1)+(ch^48);
        ch=getchar();
    }
    return s?-a:a;
}
const int mn=1e5+10;
const int mod=998244353;
ll inv[mn];
inline void init(){
    inv[1]=1;
    for(int i=2;i<=100000;i++)
        inv[i]=(ll)(mod-mod/i)*inv[mod%i]%mod;
}
int main(){
    // freopen("giveyouacandy.in","r",stdin);
    // freopen("giveyouacandy.out","w",stdout);
    int n=read<int>(),m=read<int>();
    init();
    ll ans=1;
    for(int i=1;i<=n+m;i++)
        ans=ans*i%mod;
    for(int i=1;i<=m;i++)
        ans=ans*inv[i]%mod;
    for(int i=1;i<=n;i++)
        ans=ans*inv[i]%mod;
    printf("%lld\n",ans);
    // while(1)getchar();
    return 0;
}

标签:ch,落子,格子,题解,T2,旗木,序列,棋子,Itachi
From: https://www.cnblogs.com/ex-asbable/p/17026078.html

相关文章

  • LOJ 数列分块入门 9 题解题报告
    LOJ数列分块入门9题解题报告\(\text{ByDaiRuiChen007}\)I.数列分块入门1题目大意\(\text{Link}\)维护一个长度为\(n\)的序列,支持区间加,单点查值思路分析简......
  • IntelliJ IDEA常见问题解决办法汇总
     mac上idea升级到2020.2.2后,发现versioncontrol中的localchanges不见了!解决办法:View—>ToolWIndows—>Commit【点击下,就会提示要把这个Commit放在IDEA面板那个位置,选择......
  • git 不区分大小写问题解决
    使用vscode   更改vue文件为大驼峰的方式 发现本地代码和提交时的代码名称不同是因为git不区分大小写这时我们需要找到代码存放位置 鼠标右键  GitBashHer......
  • NET2272.C 代码分析——InitProcessorSpecificConfiguration
    函数定义如下:section("L1_code")intInitProcessorSpecificConfiguration(ADI_NET2272_DEVICE*pDev){unsignedshortusValue;volatileunsignedintv;#ifdefined......
  • NET2272.C 代码分析——SetProcessorSpecificDefaultConfiguration
    section("L1_code")intSetProcessorSpecificDefaultConfiguration(ADI_NET2272_DEVICE*pDev){/*enableasyncbank3*/*pEBIU_AMGCTL|=0xF;ssync();/*defau......
  • 异地多活回环同步问题解决方案
    1.异地多活:一般为两地三中心或者三地五中心,这样设计是为了在发生单点故障或网络分区时,集群能继续提供服务。两地三中心可以容忍机房级别灾难,三地五中心可以容忍城市级别灾......
  • Codeforces Hello 2023 CF 1779 A~F 题解
    点我看题A.HallofFame先把不用操作就合法的情况判掉。然后发现交换LL,RR,RL都是没用的,只有交换LR是有用的,这样可以照亮相邻的两个位置。所以我们就是要找到一个位置i,......
  • Codeforces Hello 2023 CF 1779 A~F 题解
    点我看题A.HallofFame先把不用操作就合法的情况判掉。然后发现交换LL,RR,RL都是没用的,只有交换LR是有用的,这样可以照亮相邻的两个位置。所以我们就是要找到一个位置i,......
  • 题解 P3526 [POI2011]OKR-Periodicity
    P3526[POI2011]OKR-Periodicitynb题。先说一下这题的入手点。不妨假设一个字符串一定存在一个短周期(约定周期\(p\)满足\(2p\leq|s|\)的为短周期),假设短周期的长度......
  • 寒假第一次洛谷蓝桥个人赛 题解+补题(下)
    D.灵能传输##神仙结论把前缀和应用到极致,6先考虑三个数a,b,c,进行一次变换也就是a+b,-b,c+b可见三个数之和不变,也就是s[3]不变然后之前的s[1]+b,愿称之为s[2]之前的s......