题意:
受伤的皇后只能攻击它这一列的,和它周围的九个格子。
给定一个字符串,如果第i个字符是?则表示皇后能放在第i列的任意位置,如果不是?则表示它指定了必须放在哪一行,问有几种放法。
思路:
这种格子题目类似于小明回家,有几条路径可以选择一样,只不过初始点和结束状态不怎么一样而已。
状态:dp[i, j]表示(i, j)坐标最多有几种放法;
状态转移:dp[i, j]+=dp[k, j-1],(k取决于题目条件)。
#include <cstdio>
#include <cstring>
#define M 20
long long dp[M][M];
char str[M];
int trans(int x)
{
char ch = str[x];
if(ch>='0'&&ch<='9') return ch-'0';
else return ch-'A'+10;
}
int main ()
{
int cur;
while(~scanf("%s",str))
{
memset(dp,0,sizeof(dp));
int len = strlen(str);
if(str[0]=='?')
for(int i = 1; i <= len; i++) dp[i][1] = 1;
else
{
cur = trans(0);
dp[cur][1] = 1;
}
for(int i = 2; i <= len; i++)
{
if(str[i-1]=='?')
{
for(int j = 1; j <= len; j++)
for(int k = 1; k <= len; k++) if(k!=j&&k!=j-1&&k!=j+1)
dp[j][i] += dp[k][i-1];
}
else
{
cur = trans(i-1);
for(int k = 1; k <= len; k++) if(k!=cur&&k!=cur-1&&k!=cur+1)
dp[cur][i] += dp[k][i-1];
}
}
long long ans = 0;
for(int i = 1; i <= len; i++) ans+=dp[i][len];
printf("%lld\n",ans);
}
return 0;
}