洛谷 P1722 矩阵 II C语言 记忆化搜索

题目:

https://www.luogu.com.cn/problem/P1722

我们按照案例画一下

我们会发现,会出现重复的子结构。

代码如下:

复制代码
#include<iostream>
using namespace std;
int mem[300][300];
int n;
int f[305][305]; 
int dfs(int x,int red,int black)//x为当前格子数量,red,black分别表示为红球和黑球的数量 
{
	if(black > red || red > n)
	return 0;
	
	if(x == 2*n)
	{
		if(red == n)
		return 1;
		else
		return 0;
	}
	
	if(mem[red][black])
	return mem[red][black];
	
	int t = 0;
	t = (dfs(x+1,red+1,black)+dfs(x+1,red,black+1))%100; 
	mem[red][black] = t;
	return t;
}
int main(void)
{
	cin >> n;
	
	int ans = dfs(0,0,0);
	cout << ans;

	return 0; 
}

动态规划:

复制代码
#include<iostream>
using namespace std;
int n;
int f[305][305]; 
int main(void)
{
	cin >> n;
	

	//可以转化成有当前有i个格子有几个红色球 f[i][red]a
    f[1][1] = 1;
	for(int i = 2 ; i <= 2*n ; i++)
	{
		for(int red = (i+1)/2 ; red <= i; red++)
		{
			f[i][red] = (f[i-1][red-1] + f[i-1][red])%100;
		}
	}
	cout << f[2*n][n];
	return 0; 
}

红球的范围是生成可能和不可能的答案,但是动态规划是选择最优子结构,会筛选不可能的答案,并且不能能的答案值是0.

相关推荐
散峰而望4 分钟前
【算法竞赛】C++函数详解:从定义、调用到高级用法
c语言·开发语言·数据结构·c++·算法·github
CoderCodingNo13 分钟前
【GESP】C++五级真题(贪心思想考点) luogu-B4071 [GESP202412 五级] 武器强化
开发语言·c++·算法
我有一些感想……20 分钟前
An abstract way to solve Luogu P1001
c++·算法·ai·洛谷·mlp
前端小L21 分钟前
双指针专题(三):去重的艺术——「三数之和」
javascript·算法·双指针与滑动窗口
智者知已应修善业1 小时前
【求等差数列个数/无序获取最大最小次大次小】2024-3-8
c语言·c++·经验分享·笔记·算法
LYFlied2 小时前
【每日算法】LeetCode 416. 分割等和子集(动态规划)
数据结构·算法·leetcode·职场和发展·动态规划
多米Domi0112 小时前
0x3f 第19天 javase黑马81-87 ,三更1-23 hot100子串
python·算法·leetcode·散列表
历程里程碑2 小时前
滑动窗口最大值:单调队列高效解法
数据结构·算法·leetcode
課代表3 小时前
从初等数学到高等数学
算法·微积分·函数·极限·导数·积分·方程
ullio3 小时前
arc206d - LIS ∩ LDS
算法