【洛谷P1754 球迷购票问题】题解
卡特兰数经典 分拆问题。
分析:
题意相当于排列 个 和 个 ,使得相邻 (有序!)消掉,然后左右元素并到一起再消,最后消完的序列个数。
设 为一个组“1”, 自嵌套一次为一个组“2”(即 ),以此类推。
后面大多数数字指组“数字”
题意即转换为一个数 ,求 分解成若干个正整数之和的方案数。
神犇到这一步就可以切掉了吧。
我们这里考虑隔板法:
两个 当然可以合并 (), 和 当然可以合并 ,问题转换为有 个 有多少种合并方案。
设 个数的方案数为 。
考虑将 分解为 。
使用隔板:
- 当隔板在最左侧时,,;,因为要求合并,所以有 种,由乘法原理知,此步答案为 。
- 隔板向右移动一格,,也就是 ;,同理是 种,由乘法原理知,此步答案为 。
- 归纳一下,第 步为 。
- 最后一步显然是 ;左右对称。
于是得出递推式:
朴素 dp 即可:
#include<iostream>
using namespace std;
const int N=25;
typedef long long ll;
ll n,dp[N];
int main()
{
cin>>n;
dp[0]=1;
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
dp[i]+=dp[j-1]*dp[i-j];
cout<<dp[n];
return 0;
}
但是再深入一步,会发现 的这个 正好就是卡特兰数 ,这个公式正好是一个卡特兰数的递推式。
以下是博客签名,正文无关
本文来自博客园,作者:yspm,转载请注明原文链接:https://www.cnblogs.com/CDOI-24374/p/12853907.html
版权声明:本作品采用「署名-非商业性使用-相同方式共享 4.0 国际」许可协议(CC BY-NC-SA 4.0)进行许可。看完如果觉得有用请点个赞吧 QwQ
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】