做地宫取宝这道题可以先看一看我的博客 摘花生 这道题,题目是在这基础上增加了难度
中心思路:dp[i][j][k][v] i j 代表此时的位置 k 代表此位置 宝物的数量 v 代表当前口袋里 最大宝物的价值
#include<iostream>
#include<algorithm>
using namespace std;
int st[60][60];
long long int dp[55][55][15][15];
int n,m,k;
int mod=1000000007;
int main()
{
cin>>n>>m>>k;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
cin>>st[i][j];
st[i][j]++;
}
}
dp[1][1][0][0]=1;
dp[1][1][1][st[1][1]]=1;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
if(i==1&&j==1)continue;
for(int u=0;u<=k;u++)
{
for(int v=0;v<=13;v++)
{
dp[i][j][u][v]= (dp[i][j][u][v]+dp[i-1][j][u][v])%mod;
dp[i][j][u][v]= (dp[i][j][u][v]+dp[i][j-1][u][v])%mod;
dp[i][j][u][v]=dp[i][j][u][v]%mod;
if(u>0&&v==st[i][j])
{
for(int c=0;c<st[i][j];c++)
{
dp[i][j][u][v]=dp[i][j][u][v]+dp[i-1][j][u-1][c];
dp[i][j][u][v]=dp[i][j][u][v]+dp[i][j-1][u-1][c];
dp[i][j][u][v]=dp[i][j][u][v]%mod;
}
}
}
}
}
}
int ans=0;
for(int i=0;i<=14;i++)
{
ans=ans+dp[n][m][k][i]%mod;
ans=ans%mod;
}
cout<<ans;
return 0;
}