CSP201604-2:俄罗斯方块

引言:CSP(http://www.cspro.org/lead/application/ccf/login.jsp)是由中国计算机学会(CCF)发起的"计算机职业资格认证"考试,针对计算机软件开发、软件测试、信息管理等领域的专业人士进行能力认证。认证对象是从事或将要从事IT领域专业技术与技术管理人员,以及高校招考研究生的复试对象。

 

  • 问题描述

俄罗斯方块是俄罗斯人阿列克谢·帕基特诺夫发明的一款休闲游戏。

游戏在一个15行10列的方格图上进行,方格图上的每一个格子可能已经放置了方块,或者没有放置方块。每一轮,都会有一个新的由4个小方块组成的板块从方格图的上方落下,玩家可以操作板块左右移动放到合适的位置,当板块中某一个方块的下边缘与方格图上的方块上边缘重合或者达到下边界时,板块不再移动,如果此时方格图的某一行全放满了方块,则该行被消除并得分。

在这个问题中,你需要写一个程序来模拟板块下落,你不需要处理玩家的操作,也不需要处理消行和得分。

具体的,给定一个初始的方格图,以及一个板块的形状和它下落的初始位置,你要给出最终的方格图。

  • 输入格式

输入的前15行包含初始的方格图,每行包含10个数字,相邻的数字用空格分隔。如果一个数字是0,表示对应的方格中没有方块,如果数字是1,则表示初始的时候有方块。输入保证前4行中的数字都是0。

输入的第16至第19行包含新加入的板块的形状,每行包含4个数字,组成了板块图案,同样0表示没方块,1表示有方块。输入保证板块的图案中正好包含4个方块,且4个方块是连在一起的(准确的说,4个方块是四连通的,即给定的板块是俄罗斯方块的标准板块)。

第20行包含一个1到7之间的整数,表示板块图案最左边开始的时候是在方格图的哪一列中。注意,这里的板块图案指的是16至19行所输入的板块图案,如果板块图案的最左边一列全是0,则它的左边和实际所表示的板块的左边是不一致的(见样例)

  • 输出格式

输出15行,每行10个数字,相邻的数字之间用一个空格分隔,表示板块下落后的方格图。注意,你不需要处理最终的消行。

  • 样例输入

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 1 0 0

0 0 0 0 0 0 1 0 0 0

0 0 0 0 0 0 1 0 0 0

1 1 1 0 0 0 1 1 1 1

0 0 0 0 1 0 0 0 0 0

0 0 0 0

0 1 1 1

0 0 0 1

0 0 0 0

3

  • 样例输出

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 0 0 0

0 0 0 0 0 0 0 1 0 0

0 0 0 0 0 0 1 0 0 0

0 0 0 0 0 0 1 0 0 0

1 1 1 1 1 1 1 1 1 1

0 0 0 0 1 1 0 0 0 0

 

  • 源代码

# include <stdio.h>

# include <stdio.h>

int main(void)

{

    int current_matrix[15][10]; // 已经存在的矩阵

    int input_matrix[4][4]; // 输入的矩阵

    int place; // 放置的位置

    int c_matrix[4] = {15, 15, 15, 15};

    int i_matrix[4] = {-1, -1, -1, -1};

    

    for (int i = 0; i < 15; i++)

    {

        for (int j = 0; j < 10; j++)

        {

            scanf("%d", &current_matrix[i][j]);    

        }    

    }

    

    for (int i = 0; i < 4; i++)

    {

        for (int j = 0; j < 4; j++)

        {

            scanf("%d", &input_matrix[i][j]);

            if (input_matrix[i][j] == 1 && i > i_matrix[j])

            {

                i_matrix[j] = i;

            }

        }

    }

    

    scanf("%d", &place);

    

    for (int i = 0; i < 15; i++)

    {

        for (int j = place-1; j < place+3; j++)

        {

            if (current_matrix[i][j] == 1 && i < c_matrix[j+1-place])

            {

                c_matrix[j+1-place] = i;

            }

        }    

    }

    

    int min = 100;

    int sign = -1;

    for (int i = 0; i < 4; i++)

    {

//        printf("%d %d ", c_matrix[i], i_matrix[i]);

        if (i_matrix[i] != -1)

        {

            int diff = c_matrix[i] - i_matrix[i];

            if (diff < min)

            {

                min = diff;

                sign = i;

            }

            else if (diff == min)

            {

                if (c_matrix[i] > c_matrix[sign])

                {

                    sign = i;

                }

            }

        }

    }

    

//    printf("%d %d ", min, sign);

    

    if (sign == -1)

    {

        for (int i = 0; i < 15; i++)

        {

            for (int j = 0; j < 10; j++)

            {

                printf("%d ", current_matrix[i][j]);

            }

            printf(" ");

        }

    }

    else

    {

        int i = i_matrix[sign];

        int j = c_matrix[sign];

        for (; i >= 0; i--, j--)

        {

            for (int k = place-1; k < place+3; k++)

            {

                current_matrix[j-1][k] = current_matrix[j-1][k] + input_matrix[i][k+1-place];

            }

        }

        

        for (int i = 0; i < 15; i++)

        {

            for (int j = 0; j < 10; j++)

            {

                printf("%d ", current_matrix[i][j]);

            }

            printf(" ");

        }

    }

    

    return 0;

}

原文地址:https://www.cnblogs.com/husterzxh/p/9561482.html