题目
给定一个2N×2N的方阵网格游戏盘面,每个格子中放置一些符号。这些符号一定是成对出现的,同一个符号可能不止一对。程序读入玩家给出的一对位置(x?1,y1?? )、(x?2,y?2),判断这两个位置上的符号是否匹配。如果匹配成功,则将两个符号消为“*”并输出消去后的盘面;否则输出“Uh-oh”。若匹配错误达到3次,则输出“Game Over”并结束游戏。或者当全部符号匹配成功,则输出“Congratulations!”,然后结束游戏。
输入格式及样例
格式
输入在一行中给一个正整数N(<5)。随后2N行,每行2N个大写英文字母(其间以1个空格分隔),表示游戏盘面。盘面之后给出一个正整数K,随后K行,每行按照格式“x1y1x?2y2”给出一个玩家的输入。注意格子的行、列编号是从1到2N。
样例
2 I T I T A B A B A A A A C D C D 9 1 1 1 3 1 2 1 4 2 1 2 3 2 2 2 4 3 1 3 2 3 3 3 4 4 1 4 3 4 2 4 3 4 2 4 4
输出格式及样例
格式
根据玩家的每一步输入,输出相应的结果。输出盘面时注意,每行字符间以1个空格分隔,行末不得有多余空格。
样例
参考代码
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
void Print(int n,char**arr);
int main() {
int n,i,j;
int fail = 0,secc=0;
scanf("%d", &n);
char** arr = (char**)malloc(sizeof(char*) * 2 * n);
for (i = 1; i <= 2 * n; i++)
arr[i] = (char*)malloc(sizeof(char) * 2 * n);
for (i = 1; i <= 2 * n; i++)
for (j = 1; j <= 2 * n; j++) {
scanf("%c", &arr[i][j]);
if (arr[i][j] == ' ' || arr[i][j] == '\n')
j--;
}
int k;
scanf("%d", &k);
int** brr = (int**)malloc(sizeof(int*) * k);
for (i = 1; i <= k; i++)
brr[i] = (int*)malloc(sizeof(int) * 4);
for (i = 1; i <= k; i++)
for (j = 1; j <= 4; j++)
scanf("%d", &brr[i][j]);
for (i = 1; i <= k; i++) {
char x, y;
int x1, y1, x2, y2;
x1 = brr[i][1];
y1 = brr[i][2];
x2 = brr[i][3];
y2 = brr[i][4];
x = arr[x1][y1];
y = arr[x2][y2];
if (x == y) {
arr[x1][y1] = '*';
arr[x2][y2] = '*';
secc++;
int m = (2*n * 2*n) / 2;
if (secc == m&& n * n % 2 == 0) {
printf("Congratulation!\n");
exit(0);
}
Print(n,arr);
}
else {
printf("Uh-oh\n");
fail++;
if (fail == 3) {
printf("Game Over\n");
exit(0);
}
}
}
return 0;
}
void Print(int n,char**arr) {
for (int i = 1; i <= 2 * n; i++) {
printf("%c", arr[i][1]);
for (int j = 2; j <= 2 * n; j++) {
printf(" %c", arr[i][j]);
}
printf("\n");
}
}
|