首页 > 代码库 > wikioi 1010 过河卒
wikioi 1010 过河卒
/*
转移方程为dp[i][j]=dp[i-1][j]+dp[i][j-1]
表示到(i,j)这个格子所需要的最多的步数
注意几个特殊的地方
马所在的地方,以及i=0;j=0的时候
*/
#include <cstdio>#include <cmath>#include <cstring>#include <ctime>#include <iostream>#include <algorithm>#include <set>#include <vector>#include <sstream>#include <queue>#include <typeinfo>typedef long long ll;using namespace std;int dp[200][200];int main(){ int x,y,n,m; cin>>n>>m>>x>>y; for(int i=0;i<=n;i++) for(int j=0;j<=m;j++) dp[i][j]=1; dp[x][y]=0; dp[x+1][y+2]=0; dp[x+2][y+1]=0; if(x-1>=0)dp[x-1][y+2]=0; if(x-2>=0)dp[x-2][y+1]=0; if(x-1>=0&&y-2>=0)dp[x-1][y-2]=0; if(x-2>=0&&y-1>=0)dp[x-2][y-1]=0; if(y-1>=0)dp[x+2][y-1]=0; if(y-2>=0)dp[x+1][y-2]=0; for(int i=0;i<=n;i++) { for(int j=0;j<=m;j++) { if(!dp[i][j]) continue; if(i==0&&j==0) continue; if(i==0)dp[i][j]=dp[i][j-1]; else if(j==0)dp[i][j]=dp[i-1][j]; else dp[i][j]=dp[i-1][j]+dp[i][j-1]; } } cout<<dp[n][m]<<endl; return 0;}
wikioi 1010 过河卒
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。