C语言实现简易连连看游戏

时间:2021-12-03 04:31:08

本文为大家分享了C语言实现连连看游戏位的具体代码,供大家参考,具体内容如下

 

题目

给定一个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个空格分隔,行末不得有多余空格。

样例

C语言实现简易连连看游戏

 

参考代码

#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];
//printf("%c %c\n",x ,y);
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);
 //printf("\n");
 
}
else {
 printf("Uh-oh\n");
 fail++;
 if (fail == 3) {
  printf("Game Over\n");
  exit(0);
 }
}
//printf("%c %c\n", x, y);
/*if (arr[(brr[i][1])][(brr[i][2])] == arr[(brr[i][3])][(brr[i][4])]) {
 arr[(brr[i][1])][(brr[i][2])] = '*';
 arr[(brr[i][3])][(brr[i][4])] = '*';

 }*/

}

return 0;
}

//-----------function
void Print(int n,char**arr) {
/*char** arr = (char**)malloc(sizeof(char*) * 2 * n);
for (int i = 1; i < 2 * n; i++)
arr[i] = (char*)malloc(sizeof(char) * 2 * n);*/
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");
}

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_45823731/article/details/120140496