首页 > 其他分享 >P8386 [PA2021] Od deski do deski

P8386 [PA2021] Od deski do deski

时间:2024-03-07 10:12:10浏览次数:29  
标签:do int 显然 合法 deski 填法 P8386 数选

P8386 [PA2021] Od deski do deski

挺奇怪的一个转移式,还是套路看少了

一开始想到的是 分治,像 卡特兰数 那样求

但是发现 两端相同 这个限制的 去重 不好处理,没法划分 子问题

就比如 样例的 \(4 ~ 2\),显然包含 \(1 ~ 1 ~ 2 ~ 2\) 这种情况

当我们求 \(6 ~ 2\) 时,如果划分成 \(4 + 2\),就会有 \((1 ~ 1 ~ 2 ~ 2) ~ (X ~ X)\) 这种东西

容易注意到其在划分成 \(2 + 4\) 的时候也会出现

但显然 \(2 + 4\) 的可能划分并不 全部包含在 \(4 + 2\) 中

所以也不能直接 舍弃一种划分方式,火大

然后 直接开始看题解得到一种较好的思路

有点像 正难则反?从整体划分部分是困难的,于是我们考虑 从部分开始推出整体

注意到如果存在序列 \(S\),数 \(x\),使得 \(S + x\)(\(S\) 接上数 \(x\) 形成的 新序列)合法

则有 \(S + x + x\) 一定合法,且 \(S + x + y\)(保证 \(S + y\) 不合法时)一定不合法

如果 \(S\) 本身合法,则 \(x + x\) 构成一对即可

如果 \(S\) 不合法,则 \(S\) 中存在 \(x\),一定可以把 \(S\) 写成 合法串 \(F\) + \(x\) + 任意串 \(G\) 的形式

这样 \(S + x = F + x + G + x\),\(F\) 可以自己消掉, \(x + G + x\) 显然可以消掉,合法

而 \(S + x + x = F + (x + G + x + x)\),显然合法


而若 \(S + y\) 不合法,则 \(S\) 中不存在 \(y\) 或 \(S\) 可写作 不合法串 \(T\) + \(y\) + 任意串 \(G\) 的形式

显然 \(x \neq y\),故如果 \(S\) 中 不存在 \(y\),则 \(S + x\) 中 不存在 \(y\),显然 \(S + x + y\) 不合法

否则 \(S + x + y = T + y + G + y\),消掉 \(y + G + y\) 中剩下 不合法串 \(T\),仍然不合法

而 \(S + y + x = F + x + G + y + x\) 仍然合法

然后我们就可以推出转移式

我们设 \(f_{i, j ,0 / 1}\) 表示 当前遍历到前 \(i\) 个,下个数有 \(j\) 种填法使得 填完之后合法,以及 当前合法与否

这状态确实比较神秘...

分类讨论一下

  1. 如果当前合法,即 \(f_{i, j, 1}\)

    1. 下一个数选 \(j\) 种合法的之一,则 再下一个数 的 合法填法 数量不变

      根据上面的结论可得,于是有 \(f_{i + 1, j, 1} += j * f_{i, j, 1}\)

    2. 下一个数选 \(M - j\) 种不合法的之一,则 再下一个数 的 合法填法 增加一个

      即 \(S\) 合法且 存在 \(S + x\) 合法,而现在填了一个 \(y\),变成 \(S + y\)(并不合法)

      那么下一个数无论填 \(x\) 还是 \(y\) 均合法,也就是在原来 \(j\) 种 \(x\) 的选择下多了一种 \(y\)

      于是有 \(f_{i + 1, j + 1, 0} += (M - j) * f_{i, j, 1}\)

  2. 如果当前不合法,即 \(f_{i, j, 0}\)

    1. 下一个数选 \(j\) 种合法的之一,则 再下一个数 的 合法填法 数量不变

      根据上面的结论可得,于是有 \(f_{i + 1, j, 1} += j * f_{i, j, 0}\)

    2. 下一个数选 \(M - j\) 种不合法的之一,则 再下一个数 的 合法填法 数量不变

      这里 没有多出一种填法,当前这种情况就是原串 \(S\) 不合法,而 \(S + x\) 合法

      但我们填成了 \(S + y\),故仍不合法,显然下一个数只能填 \(x\) 才合法

      这与上面的第二种情况 对应了,有 \(f_{i + 1, j, 0} += (M - j) * f_{i, j, 0}\)

好于是四个式子就出来了,再整理一下就可以变成下面的 两个式子

\[f_{i, j, 1} = (f_{i - 1, j, 0} + F_{i - 1, j, 1}) * j \\ f_{i, j, 0} = f_{i - 1, j, 0} * (M - j) + f_{i - 1, j - 1, 1} * (M - j + 1) \]

为啥要这样转化一下?我们发现现在 \(f_i\) 中的东西只从 \(f_{i - 1}\) 中得到,然后 滚动更新 一下

非常的快啊,而且空间很小,Record

#include <bits/stdc++.h>

const int MAXN = 3005;
const int MOD  = 1000000007;

using namespace std;

long long F[MAXN][2][2];
int N, M, A;

int main () {
	
	cin >> N >> M;
	
	F[0][1][0] = 1;
	
	for (int i = 1; i <= N; ++ i) {
		for (int j = 1; j <= i; ++ j) {
			F[j][1][i & 1] = (F[j][0][(i + 1) & 1] + F[j][1][(i + 1) & 1]) * j % MOD;
			F[j][0][i & 1] = F[j][0][(i + 1) & 1] * (M - j) % MOD + F[j - 1][1][(i + 1) & 1] * (M - j + 1) % MOD;
		}
		F[0][1][i & 1] = F[0][0][i & 1] = 0;
	}
		
	for (int i = 1; i <= N; ++ i) A = (A + F[i][1][N & 1]) % MOD;
	
	cout << A << endl;
	
	return 0;
}

标签:do,int,显然,合法,deski,填法,P8386,数选
From: https://www.cnblogs.com/FAKUMARER/p/18058272

相关文章

  • CentOS7 解决宝塔面板安装 Docker 和 Docker-compose 的问题
    在宝塔面板的软件商店安装Docker管理器时提示需手动安装Docker,再在面板中开启Docker插件进行可视化管理但是我手动安装Docker后依旧提示当前未安装Docker或Docker-compose,即宝塔面板的Docker管理插件仍无法识别到这些安装,在此记录下我的解决过程,如有错误,欢迎指正!1......
  • MySQL binlog/redolog/undolog 的区别?
    想和大家聊聊InnoDB中的锁机制,那么不可避免的要涉及到MySQL的日志系统,binlog、redolog、undolog等,看到有小伙伴总结的这三个日志还不错,赶紧拿来和各位小伙伴分享。日志是 mysql 数据库的重要组成部分,记录着数据库运行期间各种状态信息。mysql日志主要包括错误日志、......
  • docker镜像
    1.base镜像base镜像有两层含义:(1)不依赖其他镜像,从scratch构建(2)其他镜像可以以之为基础进行扩展。所以,能称作base镜像的通常都是各种Linux发行版的Docker镜像,比如Ubuntu、Debian、CentOS等。dockerpullubuntuUbuntu镜像只有78M左右,下边解释为什么会这么......
  • Docker使用Dockerfile文件(五)
    前言Dockerfile是一个文本文件,其中包含了创建Docker镜像所需的所有指令。这意味着任何人都可以通过运行dockerbuild命令并使用相同的Dockerfile来创建完全相同的镜像。这确保了镜像创建的可重复性,使得在不同的环境中部署应用程序变得更加容易。Dockerfile提供了丰......
  • MAC OS :ERROR: Failed to open file '\Users\futantan\Downloads\atguigudb.sql'
    在操作source\Users\futantan\Downloads\atguigudb.sql的时候出现ERROR: Failedtoopenfile'\Users\futantan\Downloads\atguigudb.sql',error:2 解决方案,在对应的路径下开启mysql udandandeMacBook-Pro:mysqlfutantan$mysql-uroot-pEnterpassword:Welcom......
  • 电脑window系统常用快捷键
    通用快捷键Windows+D:返回桌面Ctrl+A:选择所有项目Ctrl+C:复制文字、图片、文件、文件夹等Ctrl+V:粘贴文字、图片、文件、文件夹等Ctrl+X:剪切文字、图片、文件、文件夹等Ctrl+D:删除快捷键Ctrl+M:另存为Delete:直接删除文字、图片、文件、文件夹等Ctrl+S:保存当前文本、图片、文......
  • python控制windows命令行程序
    有一些现成的库,比如WExpect,是开源的,在github上可以搜索到.但是,不知道为什么,在我自己的笔记本上不能正常工作.而其源码也比较多,懒得定位了.于是自己实现了一个,用法如下.启动和停止命令行importmy_cmdascmdcmd.start()cmd.stop()prompt命令行提示符匹......
  • 08Windows系统安装的准备工作2
    Windows系统安装的准备工作2安装虚拟机VMWareWorkStation17Pro虚拟机是一种能够模拟真正电脑的各种软硬件的软件.在对操作系统的安装不明了清晰的情况下,虚拟机是一个做实验的极佳的工具和平台.在虚拟机软件里,你可以把自己的所有操作当做在真正的电脑上一样.拥有一款虚拟机......
  • doxygen/addon/doxywizard/wizard.cpp
    Step2::Step2(Wizard*wizard,constQHash<QString,Input*>&modelData) :m_wizard(wizard),m_modelData(modelData){ QRadioButton*r; QVBoxLayout*layout=newQVBoxLayout(this); //--------------------------------------------------- m_extractMo......
  • 【Docker】Docker安装MongoDB最新版并连接使用附加docker常用命令
    【Docker】Docker安装MongoDB最新版并连接使用附加docker常用命令前言确保centos7已经安装docker,没安装docker的可以百度自行安装一、docker安装mongodb步骤1、docker拉取mongo镜像dockerpullmongo:latest2、查看本地镜像命令#查看镜像命令dockerimages#查看正在运......