C语言系列之推箱子游戏

 更新时间:2021年08月11日 14:33:18   作者:我不是小白菜  
这篇文章主要为大家详细介绍了C语言系列之推箱子游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言系列之推箱子游戏的具体代码,供大家参考,具体内容如下

输入WSAD控制行走,只需要把一个方向的代码写好了,剩下的是三个方向就是复制粘贴和简单的修改就可以了。

#include <stdio.h>
#include <conio.h>  //键盘输入函数库

//0:空地 1:墙 2:箱子要放的位置   5:人与星号重叠5:箱子与星号重叠 3:人+-3 4:箱子:+-4
int map[10][10] = {1,1,1,1,1,1,1,1,1,1,
                   1,0,0,0,0,0,2,0,0,1,
                   1,0,0,3,4,0,0,0,0,1,
                   1,0,0,1,1,0,0,0,0,1,
                   1,0,1,0,0,0,1,0,0,1,
                   1,0,0,4,0,0,1,0,0,1,
                   1,0,0,0,0,0,0,0,0,1,
                   1,0,2,0,0,0,0,0,0,1,
                   1,0,0,0,0,0,0,0,0,1,
                   1,1,1,1,1,1,1,1,1,1,
                };

int flag=0;

void PrintMap()
{
    int i, j;
    for (i = 0; i < 10; i++)
    {
        for (j = 0; j < 10; j++)
        {
            switch (map[i][j])
            {
                //0:空地 1:墙 2:箱子要放的位置 3:人 4:箱子  5:箱子到达目的地
            case 0: printf("  "); break;
            case 1: printf("■"); break;
            case 2: printf("☆"); break;
            case 3: printf("♀");  break;
            case 4: printf("□"); break;
            case 5: printf("★"); break;
            default:
                break;
            }
        }
        printf("\n");
    }
}

void PlayGame()
{
    int num = 0;
    char temp;
    temp = getch();//键盘输入无回显函数
    static int x=2,y=3;
    switch (temp)
    {
        case 'W':
        if(map[x-1][y] == 0)//如果下一个的地方为空地
        {
            if(flag == 0)
            {
                map[x-1][y] = 3;
                map[x][y] = 0;
                x--;
            }
            else
            {
                map[x-1][y] = 3;
                map[x][y] = 2;
                x--;
                flag = 0;
            }

        }
        else if (map[x-1][y] == 2)//如果下一个的地方为箱子存放地
        {
            map[x-1][y] = 3;
            map[x][y] = 0;
            x--;
            if(map[x-1][y] == 0)
            {
                flag = 1;
            }
        }
        else if(map[x-1][y] == 4)//下一个去的地方有箱子
        {

                if(map[x-2][y] == 0 )//x-2是空地时
                {
                    if(flag == 0)
                    {
                        map[x-2][y] = 4;
                        map[x-1][y] = 3;
                        map[x][y] = 0;
                        x--;
                    }
                    else
                    {
                        map[x-2][y] = 4;
                        map[x-1][y] = 3;
                        map[x][y] = 2;
                        x--;
                        flag = 0;
                    }
                }
                else if(map[x-2][y] == 2)//x-2是箱子的存放地
                {
                    map[x-2][y] = 5;
                    map[x-1][y] = 3;
                    map[x][y] = 0;
                    x--;
                }
        }

        else if (map[x-1][y] == 5)//下一个去的地方是已经在存放点的箱子
        {
            if(map[x-2][y] != 1)
            {
                map[x-2][y] = 4;
                map[x-1][y] = 3;
                map[x][y] = 0;
                x--;
                if(map[x-2][y] != 1)
                {
                    flag = 1;
                }
            }

        }
        break;

        case 'S':
        if(map[x+1][y] == 0)//如果下一个的地方为空地
        {
            if(flag == 0)
            {
                map[x+1][y] = 3;
                map[x][y] = 0;
                x++;
            }
            else
            {
                map[x+1][y] = 3;
                map[x][y] = 2;
                x++;
                flag = 0;
            }

        }
        else if (map[x+1][y] == 2)//如果下一个的地方为箱子存放地
        {
            map[x+1][y] = 3;
            map[x][y] = 0;
            x++;
            if(map[x+1][y] == 0)
            {
                flag = 1;
            }
        }
        else if(map[x+1][y] == 4)//下一个去的地方有箱子
        {

                if(map[x+2][y] == 0 )//x-2是空地时
                {
                    if(flag == 0)
                    {
                        map[x+2][y] = 4;
                        map[x+1][y] = 3;
                        map[x][y] = 0;
                        x++;
                    }
                    else
                    {
                        map[x+2][y] = 4;
                        map[x+1][y] = 3;
                        map[x][y] = 2;
                        x++;
                        flag = 0;
                    }
                }
                else if(map[x+2][y] == 2)//x-2是箱子的存放地
                {
                    map[x+2][y] = 5;
                    map[x+1][y] = 3;
                    map[x][y] = 0;
                    x++;
                }
        }

        else if (map[x+1][y] == 5)//下一个去的地方是已经在存放点的箱子
        {
            if(map[x+2][y] != 1)
            {
                map[x+2][y] = 4;
                map[x+1][y] = 3;
                map[x][y] = 0;
                x++;
                if(map[x+2][y] != 1)
                {
                    flag = 1;
                }
            }

        }
        break;

        case 'A':
        if(map[x][y-1] == 0)//如果下一个的地方为空地
        {
            if(flag == 0)
            {
                map[x][y-1] = 3;
                map[x][y] = 0;
                y--;
            }
            else
            {
                map[x][y-1] = 3;
                map[x][y] = 2;
                y--;
                flag = 0;
            }

        }
        else if (map[x][y-1] == 2)//如果下一个的地方为箱子存放地
        {
            map[x][y-1] = 3;
            map[x][y] = 0;
            y--;
            if(map[x][y-1] == 0)
            {
                flag = 1;
            }
        }
        else if(map[x][y-1] == 4)//下一个去的地方有箱子
        {

                if(map[x][y-2] == 0 )//x-2是空地时
                {
                    if(flag == 0)
                    {
                        map[x][y-2] = 4;
                        map[x][y-1] = 3;
                        map[x][y] = 0;
                        y--;
                    }
                    else
                    {
                        map[x][y-2] = 4;
                        map[x][y-1] = 3;
                        map[x][y] = 2;
                        y--;
                        flag = 0;
                    }
                }
                else if(map[x][y-2] == 2)//x-2是箱子的存放地
                {
                    map[x][y-2] = 5;
                    map[x][y-1] = 3;
                    map[x][y] = 0;
                    y--;
                }
        }

        else if (map[x][y-1] == 5)//下一个去的地方是已经在存放点的箱子
        {
            if(map[x][y-2] != 1)
            {
                map[x][y-2] = 4;
                map[x][y-1] = 3;
                map[x][y] = 0;
                y--;
                if(map[x][y-2] != 1)
                {
                    flag = 1;
                }
            }

        }
        break;

        case 'D':
        if(map[x][y+1] == 0)//如果下一个的地方为空地
        {
            if(flag == 0)
            {
                map[x][y+1] = 3;
                map[x][y] = 0;
                y++;
            }
            else
            {
                map[x][y+1] = 3;
                map[x][y] = 2;
                y++;
                flag = 0;
            }

        }
        else if (map[x][y+1] == 2)//如果下一个的地方为箱子存放地
        {
            map[x][y+1] = 3;
            map[x][y] = 0;
            y++;
            if(map[x][y+1] == 0)
            {
                flag = 1;
            }
        }
        else if(map[x][y+1] == 4)//下一个去的地方有箱子
        {

                if(map[x][y+2] == 0 )//x-2是空地时
                {
                    if(flag == 0)
                    {
                        map[x][y+2] = 4;
                        map[x][y+1] = 3;
                        map[x][y] = 0;
                        y++;
                    }
                    else
                    {
                        map[x][y+2] = 4;
                        map[x][y+1] = 3;
                        map[x][y] = 2;
                        y++;
                        flag = 0;
                    }
                }
                else if(map[x][y+2] == 2)//x-2是箱子的存放地
                {
                    map[x][y+2] = 5;
                    map[x][y+1] = 3;
                    map[x][y] = 0;
                    y++;
                }
        }

        else if (map[x][y+1] == 5)//下一个去的地方是已经在存放点的箱子
        {
            if(map[x][y+2] != 1)
            {
                map[x][y+2] = 4;
                map[x][y+1] = 3;
                map[x][y] = 0;
                y++;
                if(map[x][y+2] != 1)
                {
                    flag = 1;
                }
            }

        }
        break;
    default:
        break;
    }
}


int  main()
{
    printf("    \r\n请输入WASD控制行走\r\n");
    sleep(2);
    while ((map[1][6] != 5) || (map[7][2] != 5))
    {
        PrintMap();
        PlayGame();
        system("cls");
    }
    printf("    \n恭喜您成功通关\n\n\n");
    return 0;
}

结果显示:

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

相关文章

  • C++实现LeetCode(208.实现字典树(前缀树))

    C++实现LeetCode(208.实现字典树(前缀树))

    这篇文章主要介绍了C++实现LeetCode(208.实现字典树(前缀树)),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-08-08
  • C++深入探究类与对象之友元与运算符重载

    C++深入探究类与对象之友元与运算符重载

    友元就是让一个函数或者类,访问另一个类中的私有成员;打个比方,这相当于是说:朋友是值得信任的,所以可以对他们公开一些自己的隐私,运算符重载的实质就是函数重载或函数多态,运算符重载是一种形式的C++多态,目的在于让人能够用同名的函数来完成不同的基本操作
    2022-04-04
  • C++中的vector中erase用法实例代码

    C++中的vector中erase用法实例代码

    在vector数组中我们删除数组经常用的就是erase方法,但是earse的用法一不注意就会出错,今天我就遇到了,所以在这里总结一下,避免大家用错,对vector中erase用法感兴趣的朋友跟随小编一起看看吧
    2022-11-11
  • 浅谈#ifndef,#define,#endif的作用和用法

    浅谈#ifndef,#define,#endif的作用和用法

    下面小编就为大家带来一篇浅谈#ifndef,#define,#endif的作用和用法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • C语言使用单链表实现学生信息管理系统

    C语言使用单链表实现学生信息管理系统

    这篇文章主要为大家详细介绍了C语言使用单链表实现学生信息管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • 判断一个数是不是素数的方法

    判断一个数是不是素数的方法

    判断一个数是不是素数的方法,需要的朋友可以参考一下
    2013-03-03
  • 介绍C语言中tolower函数的实例

    介绍C语言中tolower函数的实例

    这篇文章主要介绍了介绍C语言中tolower函数的实例,本文列出了该函数的头文件,功能说明等,以及如何使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C/C++通过SQLite SDK实现数据库增删改查操作

    C/C++通过SQLite SDK实现数据库增删改查操作

    SQLite,作为一款嵌入式关系型数据库管理系统,一直以其轻量级、零配置以及跨平台等特性而备受青睐,本文主要介绍了C++如何通过SQLite SDK实现数据库增删改查操作,感兴趣的可以了解下
    2023-11-11
  • C语言 sprintf 函数详情

    C语言 sprintf 函数详情

    这篇文章主要介绍了C语言 sprintf 函数,文章主要包括sprintf 函数简介、sprintf 函数使用和简单说明了一下sprintf、fprintf、printf 函数区别,需要的朋友可以参考一下文章的具体内容
    2021-10-10
  • C语言二维数组应用实现扫雷游戏

    C语言二维数组应用实现扫雷游戏

    这篇文章主要为大家详细介绍了C语言二维数组应用实现扫雷游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06

最新评论