题面

题解

直接求解比较麻烦,考虑将问题进行转化。

设序列\(a = \{3, 1, 4, 2, 5\}, b = \{3, 2, 4, 1, 5\}\),那么我们构造一个正方形方格,将\(a\)放在横行,\(b\)放在竖行,可以画出下图。

那么我们可以发现,方案数就是从左上走到右下的不同序列个数。

这样我们可以\(\texttt{d}\texttt{p}\),设\(f[i][j]\)表示走到\((i, j)\)的方案数,那么显然\(f[i][j] = f[i - 1][j] + f[i][j - 1]\)。

不过这样转移发现有重复。考虑到\(a_i = b_j\)是\(f[i][j]\)出现重复的必要条件,通过推导可以得出方程:\(f[i][j] = f[i][j - 1] + f[i - 1][j] + [a_i = b_j]\sum_{k \geq 1}[a_{i - k} = b_{j - k}]f[i - k][j - k]\mathrm{C}(t - 1)\),其中\(\mathrm{C}\)表示卡特兰数,\(t\)表示\(1\)到\(k\)之间有多少个\(l\)满足\(a_{i - l} = b_{i - l}\)。

由于\(a_i = b_j\)只有\(n\)对,所以时间复杂度为\(\mathrm{O}(n ^ 2)\)。

代码

#include <cstdio>
#include <algorithm>
#include <vector>
#define file(x) freopen(#x".in", "r", stdin), freopen(#x".out", "w", stdout) inline int read()
{
int data = 0, w = 1; char ch = getchar();
while (ch != '-' && (ch < '0' || ch > '9')) ch = getchar();
if (ch == '-') w = -1, ch = getchar();
while (ch >= '0' && ch <= '9') data = data * 10 + (ch ^ 48), ch = getchar();
return data * w;
} const int N(2010), Mod(1e9 + 7);
int n, m, fac[N], inv[N], A[N], B[N], f[N][N];
inline int C(int n) { return 1ll * fac[n << 1] * inv[n] % Mod * inv[n + 1] % Mod; }
int fastpow(int x, int y)
{
int ans = 1;
for (; y; y >>= 1, x = 1ll * x * x % Mod)
if (y & 1) ans = 1ll * ans * x % Mod;
return ans;
} int main()
{
n = read(), m = n << 1, fac[0] = inv[0] = 1, f[1][1] = 1;
for (int i = 1; i <= m; i++) fac[i] = 1ll * fac[i - 1] * i % Mod;
inv[m] = fastpow(fac[m], Mod - 2);
for (int i = m - 1; i; i--) inv[i] = 1ll * inv[i + 1] * (i + 1) % Mod;
for (int i = 1; i <= n; i++) A[i] = read();
for (int i = 1; i <= n; i++) B[i] = read();
for (int i = 1; i <= n; i++)
for (int j = 1; j <= n; j++)
{
if (i > 1 || j > 1) f[i][j] = (f[i - 1][j] + f[i][j - 1]) % Mod;
if (A[i] == B[j]) for (int k = 1, cnt = 0; k < i && k < j; k++)
if (A[i - k] == B[j - k])
f[i][j] = (f[i][j] - 1ll * C(cnt) *
f[i - k][j - k] % Mod + Mod) % Mod, ++cnt;
}
printf("%d\n", f[n][n]);
return 0;
}

AT1879 2 つの山札的更多相关文章

  1. [ARC053D]2 つの山札

    题意:给定排列$a_{1\cdots n},b_{1\cdots n}$,执行以下操作$2n-2$次来生成一个长度为$2n-2$的序列:选择$a,b$之一(选择的序列长度要$\geq2$),删除它的第 ...

  2. HDU2063 过山车

    过山车 RPG girls今天和大家一起去游乐场玩,终于可以坐上梦寐以求的过山车了.可是,过山车的每一排只有两个座位,而且还有条不成文的规矩,就是每个女生必须找个个男生做partner和她同坐.但是, ...

  3. HDOJ 2063 过山车

    过山车 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  4. Xamarin.Android之山有木兮之木有枝,心悦君兮君不知。

    Xamarin.Android之山有木兮之木有枝,心悦君兮君不知. 第一步,写项目中的第一个界面. <?xml version="1.0" encoding ="  ...

  5. hdu 2063 过山车(匈牙利算法模板)

    http://acm.hdu.edu.cn/showproblem.php?pid=2063 过山车 Time Limit: 1000/1000 MS (Java/Others)    Memory ...

  6. HDU- 2063 过山车

    http://acm.hdu.edu.cn/showproblem.php?pid=2063 过山车//我的第一个二分匹配 Time Limit: 1000/1000 MS (Java/Others) ...

  7. hdoj 2063 过山车【匈牙利算法+邻接矩阵or邻接表】

    过山车 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  8. centos 6+安装山逗斯骚尅特(本文内容来自都比更具帝)

    系统支持:CentOS 6+,Debian 7+,Ubuntu 12+ 内存要求:≥128M 关于本脚本 一键安装 Shadowsocks-Python, ShadowsocksR, Shadowso ...

  9. 大龄剩女四大结局:孤寡 后妈 拉拉 出家 宽带山KDS-宽带山社区-第一城市消费门户

    大龄剩女四大结局:孤寡 后妈 拉拉 出家 宽带山KDS-宽带山社区-第一城市消费门户 主题:大龄剩女四大结局:孤寡 后妈 拉拉 出家

随机推荐

  1. tf.tile()函数的用法

    y = tf.tile(tf.range(2, dtype=tf.int32)[:, tf.newaxis], [2,3]) # tf.tile(input,[a,b]) 输入数据,按照对应维度将矩阵 ...

  2. Java 之 cookie 记住用户登录时间案例

    需求: 1. 访问一个Servlet,如果是第一次访问,则提示:您好,欢迎您首次访问. 2. 如果不是第一次访问,则提示:欢迎回来,您上次访问时间为:显示时间字符串 分析: 1. 可以采用Cookie ...

  3. Oracle中nlssort()函数排序功能

    转自:https://www.iteye.com/blog/libaxiaoyuan-2199851 Oracle9i之前,中文是按照二进制编码进行排序的.在oracle9i中新增了按照拼音.部首.笔 ...

  4. Linux三剑客grep/sed/awk

    grep/sed/awk被称为linux的“三剑客” grep更适合单纯的查找或匹配文本: sed更适合编辑匹配到的文本: awk更适合格式化文本,对文本进行较复杂各式处理: Grep --color ...

  5. Centos7.3安装nexus-3.14.0-04

    nexus-3.14.0-04的安装       nexus-3.14.0-04-unix.tar.gz             1.下载nexus             2.上传到服务器/root ...

  6. 【转】vsftpd用户登入不进去问题

    实在是登陆不上... 我已经加了一个新的用户UID和GID都设置到1000以后 /etc/vsftpd.conf也加了local_enable=yes 以standalone模式运行. 重启服务器后, ...

  7. while 格式化输出 运算符 字符编码

    流程控制之while循环 条件循环:while,语法如下 while 条件: # 循环体 # 如果条件为真,那么循环体则执行,执行完毕后再次循环,重新判断条件... # 如果条件为假,那么循环体不执行 ...

  8. SQL注入原理-手工联合注入查询技术

    实验报告记录 得到实验结果

  9. Linux加密和数据安全性

    加密和安全 墨菲定律 墨菲定律:一种心理学效应,是由爱德华·墨菲(Edward A. Murphy)提出的, 原话:如果有两种或两种以上的方式去做某件事情,而其中一种选择方式将导 致灾难,则必定有人会 ...

  10. Python面向对象三要素-多态

    Python面向对象3要素-多态 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.  一.多态概述 OCP原则:多用“继承”,少修改. 继承的用途:在子类上实现对基类的增强,实现多态. ...