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

编辑: admin 分类: c#语言 发布时间: 2021-12-12 来源:互联网

本文为大家分享了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个空格分隔,行末不得有多余空格。

样例

参考代码

#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");
 }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持海外IDC网。

【本文转自:http://www.1234xp.com/mgzq.html网络转载请说明出处】