是入门级动规呀

把马的位置置0即可,注意边界(窝是直接++,弄堵“墙”保护数组) xdm记得开long long !(其余没啥大事儿了)润~

using namespace std;
int n,m,x,y;
long long f[50][50];
int dx[]={0,2,1,-1,-2,-2,-1,1,2},dy[]={0,1,2,2,1,-1,-2,-2,-1};
int main(){
	ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);
	cin>>n>>m>>x>>y;
	f[1][1]=1;
	n++,m++,x++,y++;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			if(i==1&&j==1)continue; 
			f[i][j]=f[i][j-1]+f[i-1][j];
			for(int k=0;k<9;k++)
				if(i==x+dx[k]&&j==y+dy[k])f[i][j]=0;
		}
	}
	cout<<f[n][m];
	return 0;
}