社区讨论
蒟蒻60分,求助
P1002[NOIP 2002 普及组] 过河卒参与者 2已保存回复 2
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 2 条
- 当前快照
- 1 份
- 快照标识符
- @lv56gc2u
- 此快照首次捕获于
- 2024/04/18 19:47 2 年前
- 此快照最后确认于
- 2024/04/18 21:45 2 年前
代码:
CPP#include<bits/stdc++.h>
using namespace std;
int dx[]={0,2,1,-1,-2,-2,-1,1,2};
int dy[]={0,1,2,2,1,-1,-2,-2,-1};
bool b[25][25];
long long p[25][25];
int main()
{
int n,m,mx,my;
scanf("%d %d %d %d",&n,&m,&mx,&my);
for(int i=0;i<=8;i++)
{
int x=mx+dx[i];
int y=my+dy[i];
if(x>=0 && x<=n && y>=0 && y<=m) b[x][y]=1;
}
p[0][0]=1;
for(int i=0;i<=n;i++)
{
for(int j=0;j<=m;j++)
{
if(b[i][j]==0)
{
if(i==0 && j==0) continue;
if(i==0) p[i][j]=p[i][j-1];
if(j==0) p[i][j]=p[i-1][j];
if(i!=0 && j!=0) p[i][j]=p[i-1][j]+p[i][j-1];
}
}
}
printf("%d",p[n][m]);
return 0;
}
回复
共 2 条回复,欢迎继续交流。
正在加载回复...