I - 小兔的棋盘 (HDU - 2067)

Posted Alpacaddhh

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了I - 小兔的棋盘 (HDU - 2067)相关的知识,希望对你有一定的参考价值。

- 题目大意

     中文题,寻找从起点(0,0)走到终点(n,n)且不穿过对角线的最短路径数。

- 解题思路

     利用卡特兰数,地图上的点满足num[i] += num[j] * num[i - j - 1],最后卡特兰数乘2就是答案了。

- 代码

#include<iostream>
#include<cstring>
using namespace std;
const int MAX = 36;
long long num[MAX];
void find()
{
	memset(num, 0, sizeof(num));
	num[0] = num[1] = 1;
	for (int i = 2; i <= 35; i++)
		for (int j = 0; j<i; j++)
		{
			num[i] += num[j] * num[i - j - 1];
		}
}
int main()
{
	int n;
	int a = 1;
	find();
	while (cin >> n)
	{
		if (n == -1)
		{
			break;
		}
		cout << a++ << " " << n << " " << 2 * num[n] << endl;
		
	}
	return 0;
 }

  

以上是关于I - 小兔的棋盘 (HDU - 2067)的主要内容,如果未能解决你的问题,请参考以下文章

hdu2067 小兔的棋盘 DP/数学/卡特兰数

HDU2067小兔的棋盘

hdu2067 小兔的棋盘

HDU——2067 小兔的棋盘

HDU 2067 小兔的棋盘

HDU 2067 小兔的棋盘