1. 程式人生 > >7-19 簡易連連看(20 分)

7-19 簡易連連看(20 分)

7-19 簡易連連看(20 分)

本題要求實現一個簡易連連看遊戲模擬程式。

給定一個2N×2N的方陣網格遊戲盤面,每個格子中放置一些符號。這些符號一定是成對出現的,同一個符號可能不止一對。程式讀入玩家給出的一對位置(x1,y1)(x2,y2),判斷這兩個位置上的符號是否匹配。如果匹配成功,則將兩個符號消為“*”並輸出消去後的盤面;否則輸出“Uh-oh”。若匹配錯誤達到3次,則輸出“Game Over”並結束遊戲。或者當全部符號匹配成功,則輸出“Congratulations!”,然後結束遊戲。

輸入格式:

輸入在一行中給一個正整數N<5)。隨後2N行,每行2

N個大寫英文字母(其間以1個空格分隔),表示遊戲盤面。盤面之後給出一個正整數K,隨後K行,每行按照格式“x1 y1 x2 y2”給出一個玩家的輸入。注意格子的行、列編號是從1到2N

輸出格式:

根據玩家的每一步輸入,輸出相應的結果。輸出盤面時注意,每行字元間以1個空格分隔,行末不得有多餘空格。

輸入樣例1:

2
I T I T
Y T I A
T A T Y
I K K T
11
1 1 1 3
4 2 4 3
3 1 4 2
2 2 1 2
3 1 2 4
4 4 3 1
2 1 3 4
3 3 1 4
4 1 2 3
2 4 3 2
1 1 2 2

輸出樣例1:

* T * T
Y T I A
T A T Y
I K K T
* T * T
Y T I A
T A T Y
I * * T
Uh-oh
* * * T
Y * I A
T A T Y
I * * T
Uh-oh
* * * T
Y * I A
* A T Y
I * * *
* * * T
* * I A
* A T *
I * * *
* * * *
* * I A
* A * *
I * * *
* * * *
* * * A
* A * *
* * * *
Congratulations!

輸入樣例2:

2
I T I T
Y T I A
T A T Y
I K K T
5
1 1 4 4
1 1 2 3
1 1 2 3
2 2 4 1
2 2 3 3

輸出樣例2:

Uh-oh
* T I T
Y T * A
T A T Y
I K K T
Uh-oh
Uh-oh
Game Over
#include<stdio.h>
#include<math.h>
#include<stdlib.h>
#include<string.h>
int main()
{
    int n, t = 0, f = 0, i, j;
    char a[20][20];
    scanf("%d", &n);
    getchar();
    for(i = 0; i < 2*n; i++)
    {
        scanf("%c", &a[i][0]);
        for(j = 1; j < 2*n; j++)
            scanf(" %c", &a[i][j]);
        getchar();
    }
    int k, l, x1, y1, x2, y2, flag = 0;
    scanf("%d", &k);
    for(i = 0; i < k; i++)
    {
        scanf("%d%d%d%d", &x1, &y1, &x2, &y2);
        if(flag)
        {
            printf("Game Over\n");
            break;
        }
        else if(a[x1-1][y1-1] == a[x2-1][y2-1] && a[x1-1][y1-1] != '*')
        {
            t++;
            if(t == 2*n*n)
            {
                printf("Congratulations!\n");
                break;
            }
            else
            {
                a[x1-1][y1-1] = a[x2-1][y2-1] = '*';
                for(j = 0; j < 2*n; j++)
                {
                    printf("%c", a[j][0]);
                    for(l = 1; l < 2*n; l++)
                        printf(" %c", a[j][l]);
                    printf("\n");
                }
            }
        }
        else
        {
            f++;
            printf("Uh-oh\n");
            if(f == 3)
                flag = 1;
        }
    }

    return 0;
}


作者: 陳建海 單位: 浙江大學 時間限制: 400ms 記憶體限制: 64MB 程式碼長度限制: 16KB