社区讨论

蒟蒻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 条回复,欢迎继续交流。

正在加载回复...