\(\mathcal{Description}\)

  Link.

  给定 \(01\) 序列 \(\{A_n\}\) 和 \(\{B_n\}\),其中 \(1\) 的个数均为 \(k\)。记 \(A\) 中 \(1\) 的位置为 \(\{a_k\}\),\(B\) 中的为 \(\{b_k\}\)。现任意排列 \(\{a_k\}\) 和 \(\{b_k\}\),然后依次交换 \(A_{a_i}\) 和 \(A_{b_i}\),\(i=1,2,\dots,k\)。求使操作完成后 \(A=B\) 的排列方案数对 \(998244353\) 取模的结果。

  \(n\le10^4\)。

\(\mathcal{Solution}\)

  首先转化题意——每次操作用 \(A\) 的一个 \(1\) 和 \(B\) 中一个需要 \(1\) 的位置交换,共进行 \(k\) 次操作,求满足条件的方案数。

  我们定义 \(A_i=1\land B_i=0\) 的位置为“富余点”——它们需要为其它位置提供 \(1\);\(A_i=B_i=1\) 的位置为“公共点”——它们已经满足条件,但可以作为传递 \(1\) 的载体;\(A_i=0\land B_i=1\) 的位置为“缺失点”——它们是“富余点”需要提供到的位置。

  那么,只需要每个“富余点”的 \(1\) 都传递给“缺失点”,\(A\) 就与 \(B\) 相等。考虑一次从一个“富余”到“缺失”的传递,如图:

  其中三角形为“缺失点”,圆形为“公共点”(任意多个,亦可不存在),方形为“富余点”。注意若存在“公共点”,传递是不能反向的,这样会导致与三角形相邻的公共点的 \(1\) 变为 \(0\)。(某课件的笔误,注意一下 www。)


  考虑 DP,记 \(f(i,j)\) 表示在传递链中用了 \(i\) 个“公共点”,用了 \(j\) 个“富余点”(即有 \(j\) 条传递链)时,传递链中的方案数。边界为 \(f(0,0)=1\),转移:

\[f(i,j)=f(i-1,j)\cdot ij+f(i,j-1)\cdot j^2
\]

  前一项,将一个公共点加入一条传递链的末尾。有 \(j\) 条链,新的点可以与已有的 \(i-1\) 个点交换(不是交换操作顺序,而是直接交换链中位置),故有系数 \(ij\)。

  后一项,新建一条“缺失”-“富余”链。首先拿出新的一对“缺失点”和“富余点”,仍考虑到原来的“缺失点”或“富余点”可以和新点交换位置,故有系数 \(j^2\)。

  最后统计答案,发现“公共点”没有必要在链中用完,设在链中用 \(a\) 个“公共点”,还剩下 \(b\) 个。那么在所有“公共点”中选出 \(b\) 个,方案数 \(\binom{a+b}{b}\);公共点内部方案 \((b!)^2\);把这 \(b\) 次操作安排进总共 \(k\) 次操作里,方案数 \(\binom{k}{b}\)。所以设“公共点”有 \(s\) 个,“富余点”有 \(t\) 个,答案为(\(i\) 枚举的是不在链中的“公共点”个数):

\[\sum_{i=0}^{s}\binom{s}i\binom{s+t}{i}(i!)^2f(s-i,t)
\]

  复杂度 \(\mathcal O(n^2)\)。

\(\mathcal{Code}\)

  1. #include <cstdio>
  2. #include <cstring>
  3. const int MAXL = 1e4, MOD = 998244353;
  4. int n, sur, bal, f[MAXL + 5][MAXL + 5];
  5. int fac[MAXL + 5], ifac[MAXL + 5];
  6. char A[MAXL + 5], B[MAXL + 5];
  7. inline void addeq ( int& a, const int b ) { if ( ( a += b ) >= MOD ) a -= MOD; }
  8. inline int mul ( long long a, const int b ) { return ( a *= b ) < MOD ? a : a % MOD; }
  9. inline int qkpow ( int a, int b ) {
  10. int ret = 1;
  11. for ( ; b; a = mul ( a, a ), b >>= 1 ) ret = mul ( ret, b & 1 ? a : 1 );
  12. return ret;
  13. }
  14. inline void init () {
  15. fac[0] = 1;
  16. for ( int i = 1; i <= n; ++ i ) fac[i] = mul ( i, fac[i - 1] );
  17. ifac[n] = qkpow ( fac[n], MOD - 2 );
  18. for ( int i = n - 1; ~ i; -- i ) ifac[i] = mul ( i + 1, ifac[i + 1] );
  19. }
  20. inline int comb ( const int n, const int m ) {
  21. return n < m ? 0 : mul ( fac[n], mul ( ifac[m], ifac[n - m] ) );
  22. }
  23. int main () {
  24. scanf ( "%s %s", A + 1, B + 1 );
  25. n = strlen ( A + 1 ), init ();
  26. for ( int i = 1; i <= n; ++ i ) {
  27. if ( A[i] ^ '0' && B[i] ^ '0' ) ++ bal;
  28. else if ( A[i] > B[i] ) ++ sur;
  29. }
  30. f[0][0] = 1;
  31. for ( int i = 0; i <= bal; ++ i ) {
  32. for ( int j = 0, cur; j <= sur; ++ j ) {
  33. if ( ! ( cur = f[i][j] ) ) continue;
  34. addeq ( f[i + 1][j], mul ( cur, mul ( i + 1, j ) ) );
  35. addeq ( f[i][j + 1], mul ( cur, mul ( j + 1, j + 1 ) ) );
  36. }
  37. }
  38. int ans = 0;
  39. for ( int i = 0; i <= bal; ++ i ) {
  40. int fre = bal - i;
  41. int self = mul ( mul ( fac[fre], fac[fre] ),
  42. mul ( comb ( bal + sur, fre ), comb ( bal, fre ) ) );
  43. addeq ( ans, mul ( f[i][sur], self ) );
  44. }
  45. printf ( "%d\n", ans );
  46. return 0;
  47. }

Solution -「AGC 019E」「AT 2704」Shuffle and Swap的更多相关文章

  1. Solution -「CTS 2019」「洛谷 P5404」氪金手游

    \(\mathcal{Description}\)   Link.   有 \(n\) 张卡牌,第 \(i\) 张的权值 \(w_i\in\{1,2,3\}\),且取值为 \(k\) 的概率正比于 \ ...

  2. 「题解」「美团 CodeM 资格赛」跳格子

    目录 「题解」「美团 CodeM 资格赛」跳格子 题目描述 考场思路 思路分析及正解代码 「题解」「美团 CodeM 资格赛」跳格子 今天真的考自闭了... \(T1\) 花了 \(2h\) 都没有搞 ...

  3. 【翻译】西川善司的「实验做出的游戏图形」「GUILTY GEAR Xrd -SIGN-」中实现的「纯卡通动画的实时3D图形」的秘密,后篇

    http://www.4gamer.net/games/216/G021678/20140714079/     连载第2回的本回,  Arc System Works开发的格斗游戏「GUILTY G ...

  4. Android内存管理(4)*官方教程 含「高效内存的16条策略」 Managing Your App's Memory

    Managing Your App's Memory In this document How Android Manages Memory Sharing Memory Allocating and ...

  5. SSH连接时出现「WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!」解决办法

    用ssh來操控github,沒想到連線時,出現「WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!」,後面還有一大串英文,這時當然要向Google大神求助 ...

  6. 「Windows MFC 」「Edit Control」 控件

    「Windows MFC 」「Edit Control」 控件

  7. 「ZJOI2019」&「十二省联考 2019」题解索引

    「ZJOI2019」&「十二省联考 2019」题解索引 「ZJOI2019」 「ZJOI2019」线段树 「ZJOI2019」Minimax 搜索 「十二省联考 2019」 「十二省联考 20 ...

  8. Loj #6069. 「2017 山东一轮集训 Day4」塔

    Loj #6069. 「2017 山东一轮集训 Day4」塔 题目描述 现在有一条 $ [1, l] $ 的数轴,要在上面造 $ n $ 座塔,每座塔的坐标要两两不同,且为整点. 塔有编号,且每座塔都 ...

  9. Loj #6073.「2017 山东一轮集训 Day5」距离

    Loj #6073.「2017 山东一轮集训 Day5」距离 Description 给定一棵 \(n\) 个点的边带权的树,以及一个排列$ p\(,有\)q $个询问,给定点 \(u, v, k\) ...

随机推荐

  1. zabbix监控图形中文乱码的解决方法

    问题描述: 最近搭建了一套zabbix,当我把语言切换到中文的时候,发现监控的图形界面中一些中文参数乱码,但是图形界面在英文环境下完全没有乱码问题.如下图(中文界面): 解决方法: 解决方法有两种,方 ...

  2. java mapreduce实现网站PV分析

    原文链接: https://www.toutiao.com/i6765677128022229517/ PV 是Page Views的缩写,即页面浏览量,用户每一次对网站中的每个网页访问均被记录一次. ...

  3. PowerPoint2010实现折线图动态展示

    原文链接:https://www.toutiao.com/i6797629648881582596/ 我们经常会制作折线图表来表达一个过程的趋势变化,而如果让折线图动起来,会更加的生动.接下来我们将一 ...

  4. List接口的实现类

    (一): ArrayList  构造方法 特有的方法: LinkedList 特点: 可以调用Collections类的静态方法 synchronizedCollection转换成线程安全的

  5. phpAdmin写webshell的方法

    一.常规导入shell的操作    创建数据表导出shell    CREATE TABLE `mysql`.`shadow9` (`content` TEXT NOT NULL );    INSE ...

  6. 关于jar包和war读取静态文件

    在war包中static中的静态文件,打成jar包后却读取不到,这是为什么呢,让我门看下两种读取的区别 一.war包中都取静态模板文件 public static void download(Stri ...

  7. windows server 服务器安装jenkins 并通过git拉取代码实现自动发布到IIS

    Jenkins是一个开源软件,可以通过一定的配置进行自动构建,测试,部署等功能. 首先,服务器应安装好 .NET Core环境和JDK, 下载Jenkins安装包 https://www.jenkin ...

  8. k8s-pv-pvc

    1. 简介 持久卷(PersistentVolume,PV)是集群中的一块存储,可以由管理员事先供应,或者 使用存储类(Storage Class)来动态供应. 持久卷是集群资源,就像节点也是集群资源 ...

  9. NPOI导出例子

    public static string ExportAOrder(ExportData data) { var cellHeard = new Dictionary<string, strin ...

  10. Python向mysql数据库插入数据

    一.向表tcolor中插入数据的主要流程如下: import datetimeimport pymysql.cursorsconnection = pymysql.connect(host='loca ...