Hetao P1287 小核桃玩核桃棋 题解 [ 蓝 ] [ 观察 ] [ 二维 dp ] [ 容斥原理 ]

news/2025/3/11 0:28:24/文章来源:https://www.cnblogs.com/zhr0102/p/18764043

小核桃玩核桃棋:质量挺高的一道 dp,好像是搬的某场神秘 ICPC 的?

image
image
image
image

观察

首先我们观察最优解有什么性质,显然这个问题就是要我们选择一些点覆盖所有的行与列。贪心地考虑,不难想出我们从 \((1,1)\) 开始按照对角线来放置,就一定能取到最优解。

那么我们把这个对角线框出的矩形边长设为 \(d\),于是最优解需要放置的个数便是 \(d\) 了。

那么取到最优解的条件是什么呢?我们考虑调整这个对角线放置的方法,将棋子上下移动,不难发现这些棋子在覆盖这 \(d\) 行或 \(d\) 列的同时还能覆盖掉剩余的格子。简而言之,就是最优解只会有下面两种情况:

  • \(d\) 行内每一行都有棋子,并且最后剩下的行都通过纵向覆盖了。
  • \(d\) 列内每一列都有棋子,并且最后剩下的行都通过横向覆盖了。

那么有没有可能出现 \(d\) 行内某一行没有被横向覆盖的情况呢?显然是没有的,因为如果不直接横向覆盖就要花更多地代价去纵向覆盖它,显然不优。

容斥

所以我们就可以利用这个性质设计 dp 了,最后的答案根据容斥原理,就是分别满足两个条件的方案总数减去同时满足两个条件的方案数。

同时满足的方案数是好求的,显然是 \(d!\),考虑如何对每个条件单独求解。

我们假设现在求解的是第二种情况,后面要求横向覆盖的行数是前 \(r\) 行。

定义 \(dp_{i,j}\) 表示考虑到前 \(i\) 列,前 \(r\) 行中已经有 \(j\) 行被覆盖过了,则转移有下面两种:

  • 对覆盖有效的转移:\(dp_{i+1,j+1}\gets dp_{i+1,j+1}+dp_{i,j}\times (r-j)\)
  • 对覆盖无意义的转移:\(dp_{i+1,j}\gets dp_{i+1,j}+dp_{i,j}\times (a_{i+1}-r+j)\),这里 \(a_{i+1}-r+j\) 是除了覆盖后可能影响结果的行数。

转移即可,时间复杂度 \(O(n^2)\),问了几个数竞佬都不会这个的线性求法,平方应该就是最优解了。

代码

#include <bits/stdc++.h>
#define fi first
#define se second
#define eb(x) emplace_back(x)
#define pb(x) push_back(x)
#define lc(x) (tr[x].ls)
#define rc(x) (tr[x].rs)
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef long double ldb;
using pi=pair<int,int>;
const int N=5005;
const ll mod=1000000007;
int n,a[N],d,c[N];
ll ans1=1,ans2,ans3,dp[N][N];
ll cal(int *b,int r)
{memset(dp,0,sizeof(dp));dp[0][0]=1;for(int i=0;i<d;i++){for(int j=0;j<=r;j++){dp[i+1][j]=(dp[i+1][j]+dp[i][j]*(b[i+1]-r+j)%mod)%mod;if(j+1<=r)dp[i+1][j+1]=(dp[i+1][j+1]+dp[i][j]*(r-j)%mod)%mod;}}return dp[d][r];
}
int main()
{//freopen("sample.in","r",stdin);//freopen("sample.out","w",stdout);ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);cin>>n;for(int i=1;i<=n;i++)cin>>a[i];for(d=0;d+1<=n&&d+1<=a[d+1];d++);for(ll i=1;i<=d;i++)ans1=(ans1*i)%mod;ans2=cal(a,a[d+1]);for(int i=n;i>=1;i--)for(int j=a[i];j>a[i+1];j--)c[j]=i;ans3=cal(c,c[d+1]);cout<<((ans2+ans3-ans1)%mod+mod)%mod;return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/897058.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

GAMMA: Revisiting Template-based Automated Program Repair via Mask Prediction 论文笔记

介绍 (1) 发表 2023-09 ASE23 (2) 背景 基于模版的 APR 采用了由人类专家手工制作的维修模式将错误代码片段转变为正确代码片段,被认为是最先进的,大量研究专门用于模版提取方案。然而以前的工作显示出相当数量的错误无法修复,因为相关的错误代码在本地文件中不可用基于深度…

基于模糊PID控制的六步逆变器供电无刷直流电机调速simulink仿真

1.课题概述基于模糊PID控制的六步逆变器供电无刷直流电机调速simulink仿真.将仿真结果和传统的PID控制器的仿真结果进行对比。2.系统仿真结果 (完整程序运行后无水印)1.转速对比,并局部放大显示2.电流对比,并局部放大显示3.电压对比,并局部放大显示4.Te对比,并局部放大显…

Xshell连接虚拟机

Xshell连接Linux虚拟机为了熟悉设用Xshell,但是没卖远程虚拟机,今天使用Xshell连接虚拟机先安装好Xshell进入虚拟机root用户在Linux中输入ip addr指令在输入vi /etc/sysconfig/network-scripts/ifcfg-ens33这里的ens33以上面红框的为准这里要把ONBOOT赋值yes,到这里发现自己…

泵浦光与斯托克斯光相遇耦合效应的matlab模拟与仿真

1.程序功能描述泵浦光与斯托克斯光相遇耦合效应的matlab模拟与仿真. 2.测试软件版本以及运行结果展示MATLAB2022A版本运行 (完整程序运行后无水印) 3.核心程序figure(1); subplot(211);plot(dt:dt:tmax,Ip(:,1)); subplot(212);plot(dt:dt:tmax,Is(:,LL-1));%定义计数器 i =…

一、MyBatis简介:MyBatis历史、MyBatis特性、和其它持久化层技术对比、Mybatis下载依赖包流程

一、MyBatis简介:MyBatis历史、MyBatis特性、和其它持久化层技术对比、Mybatis下载依赖包流程@目录一、MyBatis简介1.1 MyBatis历史1.2 MyBatis特性1.3 和其它持久化层技术对比1.4 Mybatis下载依赖包流程本人其他相关文章链接 一、MyBatis简介 1.1 MyBatis历史 ​ MyBatis最初…

Qt5.14.2用CMake创建项目(适配VS2022编译器)

本篇指得是用Qt创建项目并开发,以CMake的方式,使用VS的编译器。 至于用VS开发Qt项目,很容易配置。 ------------------------ 正文 -------------------------------- Qt5.14.2只能使用VS2015或2017版本的编译器,所以Qt安装时我勾选VS2017 64bit,那么VS2022安装时也要勾选…

应急响应靶场之vulntarget-n

vulntarget-n 用户名密码:root/Vulntarget@123 一.分析history命令 1.先将历史命令导出 history > 1.txt 2.分析history 1)篡改网页2)将木马文件进行伪装3)创建公钥私钥,加密方式为rsa4)拷贝公钥到指定目录,将该目录下文件进行勒索加密二.找到加密私钥进行解密 find …

【PHP反序列号漏洞】样本解析

来源 第六届浙江省大学生网络与信息安全竞赛 2023年 初赛/决赛 WEB方向 Writeup分析: __toString() 在PHP中,Exception::__toString是一个魔术方法(Magic Method),用于定义当尝试将对象作为字符串输出时的行为。具体来说,当一个异常对象(通常是Exception类或其子类的实例…

依赖注入 DI综合案例

依赖注入 DI综合案例 需求说明先建一个ConsoleMailSend总项目,然后建一个类库项目声明一个接口:using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;namespace LogServices {public interface IlogProvid…

《深入理解计算机网络》 | PDF免费下载 | free download

《深入理解计算机网络》是计算机网络领域的扛鼎之作,由有20余年从业经验的优秀网络技术工程师兼全国网管技能水平开始认证专家王达老师撰写,51CTO技术社区鼎力推荐,权威性毋庸置疑。内容方面,本书结合最新计算机网络技术,全面、系统、深入地阐述了计算机网络的体系结构、工…

《深入理解LINUX内核(第三版)》 | PDF免费下载 | epub free download

《深入理解Linux内核》第3版 将使你了解Linux的所有内部工作,它不仅仅是一个理论上的练习。你将学习到哪些情况下Linux性能最佳,并且你将看到,在大量的不同环境里进行进程调度、文件存取和内存管理时它如何满足提供良好的系统响应的需要。这本书将帮助你充分利用Linux系统。…