题目链接
题意
A 点有一个过河卒,需要走到目标 B 点。卒可以向下或向右走。棋盘上有一些对方的马。卒不能通过对方马的控制点。
棋盘用坐标表示,现在要求你计算出卒从 A 点能够到达 B 点的路径的条数。
思路
- dp[i][j]表示达到i,j位置的路径数
- 由于只能向下和向右走,dp[i][j]=dp[i][j-1]+dp[i-1][j]
- 注意开long long
参考代码
#include<bits/stdc++.h>
using namespace std;
long long dp[25][25];
int yd[9][2]={{0,0},{1,2},{1,-2},{-1,2},{-1,-2},{-2,-1},{-2,1},{2,1},{2,-1}};
int n,m,x,y;
int judge(int i,int j)
{
for(int k=0;k<9;k++)
{
if(i==x+yd[k][0]&&j==y+yd[k][1])
{
return true;
}
}
return false;
}
int main()
{
cin>>n>>m>>x>>y;
n++;
m++;
x++;
y++;
dp[0][1]=1;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
if(!judge(i,j))
{
dp[i][j]=dp[i][j-1]+dp[i-1][j];
}
}
}
cout<<dp[n][m]<<endl;
}