社区讨论

新手求助(会guanzhu

P1002[NOIP 2002 普及组] 过河卒参与者 4已保存回复 5

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
5 条
当前快照
1 份
快照标识符
@m1ue4zyk
此快照首次捕获于
2024/10/04 15:15
去年
此快照最后确认于
2025/11/04 18:06
4 个月前
查看原帖
C
#include <stdio.h>

int main() {
	int Bx, By, Cx, Cy;
	scanf("%d %d %d %d", &Bx, &By, &Cx, &Cy);
	int A[Bx+1][By+1];
	for (int i = 0; i <= Bx; i++) {
		for (int j = 0; j <= By; j++) {
			A[i][j] = 0;
		}
	}
	A[Cx][Cy] = -1;
	
	int moves[8][2] = {
		{-2, -1}, {-1, -2}, {1, -2}, {2, -1},
		{2, 1}, {1, 2}, {-1, 2}, {-2, 1}
	};
	for (int i = 0; i < 8; i++) {
		int newX = Cx + moves[i][0];
		int newY = Cy + moves[i][1];
		if (newX >= 0 && newX <= Bx && newY >= 0 && newY <= By) {
			A[newX][newY] = -1;
		}
	}
	
	
	int dp[Bx+1][By+1];
	for (int i = 0; i <= Bx; i++) {
		for (int j = 0; j <= By; j++) {
			dp[i][j] = 0;
		}
	}
	dp[0][0] = 1;
	
	for (int i = 0; i <= Bx; i++) {
		for (int j = 0; j <= By; j++) {
			if (A[i][j] == 0) { 
				if (i > 0) dp[i][j] += dp[i-1][j]; 
				if (j > 0) dp[i][j] += dp[i][j-1]; 
			}
		}
	}
	
	printf("%d", dp[Bx][By]);

	return 0;
}
为什么第3、4个测试点没过QaQ,或者能告诉我这两个测试样例是什么吗

回复

5 条回复,欢迎继续交流。

正在加载回复...