Vijos 1121 马拦过河卒
2015-09-20 16:42
344 查看
首先要看清题目,卒只能向右或者向下走。而不是四周转。这样的话就无解了。
定义f[i][j],表示走到(i,j)这个点时的总步数。这样就写出了一个递推公式f[i][j]=f[i-1]+f[i][j-1]。因为卒是从(0,0)出发,所以f[0][0]=1,因为 f[i][j]只能从前一个状态转移过来。所以在转移前需要加特判即(i-1,j)和(i,j-1)两点不是马所控制的点。所以在递推之前还应有一个预处理。来处理马所能控制的点,预处理很好写。剩下的没有什么了。输出目标节点的 f 值即可。
代码:
定义f[i][j],表示走到(i,j)这个点时的总步数。这样就写出了一个递推公式f[i][j]=f[i-1]+f[i][j-1]。因为卒是从(0,0)出发,所以f[0][0]=1,因为 f[i][j]只能从前一个状态转移过来。所以在转移前需要加特判即(i-1,j)和(i,j-1)两点不是马所控制的点。所以在递推之前还应有一个预处理。来处理马所能控制的点,预处理很好写。剩下的没有什么了。输出目标节点的 f 值即可。
代码:
#include<iostream> #include<cstdio> using namespace std; int x1,y1,x2,y2; int f[16][16],a[16][16],ans; int mx[8]={1,2,2,1,-1,-2,-2,-1}; int my[8]={2,1,-1,-2,-2,-1,1,2}; int main() { scanf("%d%d%d%d",&x1,&y1,&x2,&y2); a[x2][y2]=1; for(int i=0;i<=7;i++){ if(x2+mx[i]<=x1&&y2+my[i]<=y1) a[x2+mx[i]][y2+my[i]]=1; } f[0][0]=1; for(int i=0;i<=x1;i++) for(int j=0;j<=y1;j++){ if(i>0&&!a[i-1][j]) f[i][j]+=f[i-1][j]; if(j>0&&!a[i][j-1]) f[i][j]+=f[i][j-1]; } printf("%d",f[x1][y1]); }
相关文章推荐
- 1.1Linux 系统简介(学习过程)
- linux常用命令(42):ping 命令
- C++中接口与抽象类
- js之节点属性
- 软件工程之宏观把握
- 【小知识点总结】去掉ScrollVIew拉到尽头时再拉的阴影效果
- Argument-Dependent Lookup (aka ADL, or “Koenig Lookup”)
- UVa1225——Digit Counting
- 杭电acm--2031
- 表格资料
- Hyperreal number
- Dual Number
- Android 裁剪图片为圆形图片
- 友元的用法
- reformatvob命令描述
- Android运用Handler和Message实现异步更新UI界面
- 数据库(设计)中的范式
- 获取url参数
- Lowest Common Ancestor of a Binary Tree——Leetcode
- 1.12Linux下软件安装(学习过程)