zoukankan      html  css  js  c++  java
  • Vijos 1121 马拦过河卒

    首先要看清题目,卒只能向右或者向下走。而不是四周转。这样的话就无解了。

    定义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]);
    }
  • 相关阅读:
    List注意点【修改】
    最近遇到的笔试面试题(3)
    关于阅读
    各种语言
    最近遇到的笔试面试题(2)
    最近遇到的笔试面试题(1)
    5自由落体运动
    4 1000以内完数
    3水仙花数
    判断101-200之间的素数
  • 原文地址:https://www.cnblogs.com/xtx1999/p/4823720.html
Copyright © 2011-2022 走看看