本文共 1881 字,大约阅读时间需要 6 分钟。
本题要求实现一个简易连连看游戏模拟程序。
给定一个2N×2N的方阵网格游戏盘面,每个格子中放置一些符号。这些符号一定是成对出现的,同一个符号可能不止一对。程序读入玩家给出的一对位置(x1,y1 )、(x2,y2),判断这两个位置上的符号是否匹配。如果匹配成功,则将两个符号消为“*”并输出消去后的盘面;否则输出“Uh-oh”。若匹配错误达到3次,则输出“Game Over”并结束游戏。或者当全部符号匹配成功,则输出“Congratulations!”,然后结束游戏。
输入格式:
输入在一行中给一个正整数N(<5)。随后2N行,每行2N个大写英文字母(其间以1个空格分隔),表示游戏盘面。盘面之后给出一个正整数K,随后K行,每行按照格式“x1y1x2y2”给出一个玩家的输入。注意格子的行、列编号是从1到2N。输出格式:
根据玩家的每一步输入,输出相应的结果。输出盘面时注意,每行字符间以1个空格分隔,行末不得有多余空格。输入样例1:
输出样例1:
输入样例2:
输出样例2:#include#include //内含exit()函数void print(int n, char a[10][10]); //输出字符串数组函数int main(){ int n, k, count = 0, fail = 0; char a[10][10]; scanf("%d", &n); for (int i = 1; i <= 2 * n; i++) for (int j = 1; j <= 2 * n; j++) { scanf("%c", &a[i][j]); if (a[i][j] == ' ' || a[i][j] == '\n') //过滤无效字符 j--; } scanf("%d", &k); for (int i = 1; i <= k; i++) { int x1, x2, y1, y2; scanf("%d %d %d %d", &x1, &y1, &x2, &y2); if (a[x1][y1] == a[x2][y2] && a[x1][y1] != '*') { a[x1][y1] = a[x2][y2] = '*'; count += 2; if (count != 2 * n * 2 * n) print(n, a); } else if (a[x1][y1] != a[x2][y2] || a[x1][y1] == '*' && a[x2][y2] == '*') { fail++; printf("Uh-oh\n"); } if (count == 2 * n * 2 * n) { printf("Congratulations!"); exit(0); //直接退出程序 } if (fail == 3) { printf("Game Over"); exit(0); } } return 0;}void print(int n, char a[10][10]){ for (int i = 1; i <= 2 * n; i++) { for (int j = 1; j <= 2 * n; j++) { if (j == 1) printf("%c", a[i][j]); else printf(" %c", a[i][j]); } printf("\n"); } }
转载地址:http://hgtlf.baihongyu.com/