Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
104787 | 李承瀚 | 过河卒 | C++ | 通过 | 100 | 0 MS | 268 KB | 705 | 2023-10-04 09:31:29 |
#include<iostream> #include<cstring> #include<cstdio> #include<algorithm> #define ll long long using namespace std; const int fx[] = {0, -2, -1, 1, 2, 2, 1, -1, -2}; const int fy[] = {0, 1, 2, 2, 1, -1, -2, -2, -1}; int bx, by, mx, my; ll f[40][40]; bool s[40][40]; int main(){ scanf("%d%d%d%d", &bx, &by, &mx, &my); bx += 2; by += 2; mx += 2; my += 2; f[2][1] = 1; s[mx][my] = 1; for(int i = 1; i <= 8; i++) s[mx + fx[i]][my + fy[i]] = 1; for(int i = 2; i <= bx; i++){ for(int j = 2; j <= by; j++){ if(s[i][j]) continue; f[i][j] = f[i - 1][j] + f[i][j - 1]; } } printf("%lld\n", f[bx][by]); return 0; }