C语言控制台打砖块小游戏

 更新时间:2022年05月11日 15:53:32   作者:锦鲤金叔叔  
这篇文章主要为大家详细介绍了C语言控制台打砖块小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文为大家分享了C语言控制台小游戏,打砖块,供大家参考,具体内容如下

这个问题是我在领扣上面看到的一道困难问题,原题是这样的:

#include "stdafx.h"
#include<stdio.h>
int a[10][10] = { { 0, 0, 1, 0, 0, 0, 0, 0, 1, 0 }, 
                  { 0, 0, 1, 1, 1, 1, 0, 1, 1, 0 },
                  { 0, 0, 0, 0, 1, 1, 0, 1, 1, 0 },
                  { 0, 1, 1, 1, 1, 1, 0, 0, 1, 0 },
                  { 0, 0, 0, 0, 0, 0, 0, 1, 1, 0 },
                  { 0, 0, 0, 0, 0, 0, 1, 1, 1, 1 },
                  { 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, 0, 1, 0, 0, 0, 0, 0 } };//初始化二维数组,写成这个形状便于一目了然

void down(int a[10][10])//负责控制砖块下落的函数,使被赋值为3的砖块下落,下落到下界或值为1的方块之上
{
    int i, j;
    int m, n;
    for (i = 9; i >=0; i--)
    for (j = 0; j < 10; j++)
    if (a[i][j] == 3)
    {
        m = i;
        n = j;
        while (a[m + 1][n] != 1&&m!=9)
        {
            a[m + 1][n] = 1;
            a[m][n] = 0;
            m++;
        }
    }
}

void freshen(int a[10][10])//刷新函数,用于每次打过砖块之后,检查所有砖块的松动情况,过程大概是这样的,先将全部为1的砖块赋值为3,之后将四周与墙壁相连并且值为3的砖块赋值为·1,然后再进行一次全体砖块的循环遍历,这一次将所有与1相连接(1上下左右连接的砖块并且值为3的)的砖块赋值为1,这样的操作要做四遍,为什么要做这么多遍,这个问题留给读者体会。
{
    int i, j;
    for ( i = 0; i < 10; i++)
    for ( j = 0; j < 10; j++)
        if (a[i][j]==1)
            a[i][j] = 3;
        for (i = 0; i < 10; i++)
        {
            j = 0;
            while (a[i][j] != 0)
            {
                a[i][j] = 1;
                j++;
            }
        }
        for (i = 0; i < 10; i++)
        {
            j = 9;
            while (a[i][j] != 0)
            {
                a[i][j] = 1;
                j--;
            }
        }
        for (j = 0; j < 10; j++)
        {
            i = 0;
            while (a[i][j] != 0)
            {
                a[i][j] = 1;
                i++;
            }
        }
        for (j = 0; j < 10; j++)
        {
            i = 9;
            while (a[i][j] != 0)
            {
                a[i][j] = 1;
                i--;
            }
        }
        for (i = 0; i < 10; i++)
        for (j = 0; j < 10; j++)
        if (a[i][j] == 1)
        {
            if (a[i - 1][j] == 3)
                a[i - 1][j] = 1;
            else
            if (a[i + 1][j] == 3)
                a[i + 1][j] = 1;
            else
            if (a[i ][j-1] == 3)
                a[i ][j-1] = 1;
            else
            if (a[i ][j+1] == 3)
                a[i ][j+1] = 1;
        }
        for (i = 9; i >=0; i--)
        for (j = 9; j >=0; j--)
        if (a[i][j] == 1)
        {
            if (a[i - 1][j] == 3)
                a[i - 1][j] = 1;
            else
            if (a[i + 1][j] == 3)
                a[i + 1][j] = 1;
            else
            if (a[i][j - 1] == 3)
                a[i][j - 1] = 1;
            else
            if (a[i][j + 1] == 3)
                a[i][j + 1] = 1;
        }
        for (i = 9; i >= 0; i--)
        for (j = 9; j >= 0; j--)
        if (a[i][j] == 1)
        {
            if (a[i - 1][j] == 3)
                a[i - 1][j] = 1;
            else
            if (a[i + 1][j] == 3)
                a[i + 1][j] = 1;
            else
            if (a[i][j - 1] == 3)
                a[i][j - 1] = 1;
            else
            if (a[i][j + 1] == 3)
                a[i][j + 1] = 1;
        }
        for (i = 9; i >= 0; i--)
        for (j = 9; j >= 0; j--)
        if (a[i][j] == 1)
        {
            if (a[i - 1][j] == 3)
                a[i - 1][j] = 1;
            else
            if (a[i + 1][j] == 3)
                a[i + 1][j] = 1;
            else
            if (a[i][j - 1] == 3)
                a[i][j - 1] = 1;
            else
            if (a[i][j + 1] == 3)
                a[i][j + 1] = 1;
        }
}

void view(int a[10][10])//打印砖块函数
{
    for (int i = -1; i < 10; i++)
    {
        printf("0%d ", i);
    }
    printf("\n");
    for (int i = 0; i < 10; i++)
    {
        printf("%d:  ", i);
        for (int j = 0; j < 10; j++)
        {
            if (a[i][j] == 1)
                printf("*  ");
            else
                printf("   ");
        }
        printf("\n");
    }
}

void beat(int a[10][10],int i,int j)//打砖块函数
{
    a[i][j] = 0;
}

void main()
{
    int p,q;
    view(a);
    for (int w = 0; w < 18; w++)
    {
        printf("beat whichp?\n");
        scanf("%d", &p);
        printf("beat whichq?\n");
        scanf("%d", &q);
        beat(a, p, q);
        freshen(a);
        down(a);
        view(a);
    }
    getchar();
    return;
}

我用到的编译器是VS2013,C语言写控制台程序,大一初学C语言的同学们可以看一下这个编程思想。
最后的效果是这样的:

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

相关文章

  • C++位操作的常见用法小结

    C++位操作的常见用法小结

    这篇文章主要介绍了C++位操作的常见用法,包括了判断奇偶、交换两个数、正负转换、求绝对值等,需要的朋友可以参考下
    2014-09-09
  • C语言中读写交替时出现的问题分析

    C语言中读写交替时出现的问题分析

    读写命令交替,一定要使用fseek重新定位,否则出现输入显示混乱,这篇文章主要介绍了C语言中读写交替时出现的问题分析,需要的朋友可以参考下
    2022-12-12
  • 详解C语言gets()函数与它的替代者fgets()函数

    详解C语言gets()函数与它的替代者fgets()函数

    这篇文章主要介绍了详解C语言gets()函数与它的替代者fgets()函数的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-10-10
  • 如何使用递归和非递归方式反转单向链表

    如何使用递归和非递归方式反转单向链表

    以下是对使用递归和非递归方式反转单向链表的示例进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-07-07
  • 基于一致性hash算法 C++语言的实现详解

    基于一致性hash算法 C++语言的实现详解

    在《基于一致性hash算法(consistent hashing)的使用详解》一文中已经介绍了一致性hash的基本原理,本文将会对其具体实现细节进行描述,并用c++语言对一致性hash进行了简单的实现
    2013-05-05
  • C++中四种加密算法之DES源代码

    C++中四种加密算法之DES源代码

    本篇文章主要介绍了C++中四种加密算法之DES源代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。
    2016-11-11
  • windows下用c++获取本机ip地址的三种方法

    windows下用c++获取本机ip地址的三种方法

    工作过程中遇到一个需求,需要获取本机ip地址,同时获取本机网络连接情况,即网线是否连接,经过多番搜索,本文给大家介绍了3种方案,通过代码示例介绍的非常详细,需要的朋友可以参考下
    2023-11-11
  • C++超详细分析优化排序算法之堆排序

    C++超详细分析优化排序算法之堆排序

    堆是计算机科学中一类特殊的数据结构的统称,通常是一个可以被看做一棵完全二叉树的数组对象。而堆排序是利用堆这种数据结构所设计的一种排序算法。本文将通过图片详细介绍堆排序,需要的可以参考一下
    2023-02-02
  • 奇怪的C语言特性

    奇怪的C语言特性

    下面列出的特性未必奇怪,有的算是有趣
    2013-04-04
  • C++初始化函数列表详细解析

    C++初始化函数列表详细解析

    C++可以定义引用类型的成员变量,引用类型的成员变量必须在构造函数的初始化列表中进行初始化
    2013-09-09

最新评论