社区讨论

帮忙看一下吧,dfs+记忆化有两个点过不去

P1164小 A 点菜参与者 1已保存回复 0

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
0 条
当前快照
1 份
快照标识符
@lt2q0zzh
此快照首次捕获于
2024/02/26 17:13
2 年前
此快照最后确认于
2024/02/26 17:28
2 年前
查看原帖
CPP
#include<iostream> 
#include<cmath>
#include<cstring>
using namespace std;
int n,m; 
int a[102];
int mem[102][102];
//当前到了第x个菜,还剩sm元 
int dfs(int x,int sm){
	if(mem[x][sm]) return mem[x][sm];
	int rs=0;
	if(x>n) rs=0;
	else if(sm<a[x]) rs=dfs(x+1,sm);//剩余钱不够 
	else if(sm>a[x]) rs=dfs(x+1,sm)+dfs(x+1,sm-a[x]);//选这道菜与不选 
	else if(sm==a[x]) rs=dfs(x+1,sm)+1;//剩余钱刚好够这道菜 选与不选 
	mem[x][sm]=rs;
	return rs;
}
int main(){
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		cin>>a[i];
	} 
	cout<<dfs(1,m);
	return 0;
} 

回复

0 条回复,欢迎继续交流。

正在加载回复...