文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言系列之推箱子游戏

2024-04-02 19:55

关注

本文实例为大家分享了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;
}

结果显示:

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯