话不多说直接上代码

  

using System;

namespace Boxer
{
class Program
{
const int WIDTH = 8;
const int HEIGHT = 8;
static int[,] map = new int[HEIGHT, WIDTH]{
{0, 0, 1, 1, 1, 0, 0, 0},
{0, 0, 1, 4, 1, 0, 0, 0},
{0, 0, 1, 0, 1, 1, 1, 1},
{1, 1, 1, 3, 0, 3, 4, 1},
{1, 4, 0, 3, 2, 1, 1, 1},
{1, 1, 1, 1, 3, 1, 0, 0},
{0, 0, 0, 1, 4, 1, 0, 0},
{0, 0, 0, 1, 1, 1, 0, 0}
};
static int x, y;
static int boxs; /**
* 0 表示空
* 1 表示墙
* 2 表示人
* 3 表示箱子
* 4 表示目的地(球)
* 5 表示已完成的箱子
*/
static void Main(string[] args)
{ char direction; //存储键盘按的方向
initData(); //初始化一些数据 //开始游戏的循环,这里是个死循环,每按一次按钮循环一次
while (true)
{
//每次循环的开始清除屏幕
//system("cls");
Console.Clear();
//绘画地图
drawMap(); //判断,当boxs的数量0时,!0为真,然后走break跳出循环(结束游戏)
if (boxs == 0)
{
break;
} //键盘输入方向,这里使用getch,因为getch读取字符不会显示在屏幕上
direction = Console.ReadKey().KeyChar; //用switch判断用户输入的方向
switch (direction)
{
case 'w':
//按w时,调用向上移动函数
moveUp();
break;
case 'a':
//按a时,调用向左移动函数
moveLeft();
break;
case 's':
moveDown();
break;
case 'd':
moveRight();
break;
}
}
//当跳出循环时,运行该语句,游戏结束
Console.WriteLine("恭喜你完成游戏!※");
Console.ReadKey(); } //初始化一些数据
public static void initData()
{
int i, j; //加载数据时让用户等待,一般情况加载数据比较快
Console.WriteLine("游戏加载中,请稍后........."); //遍历地图中的数据
for (i = 0; i < HEIGHT; i++)
{
for (j = 0; j < WIDTH; j++)
{
//遍历到2(人)时,记录人的坐标。x, y是前面定义的全局变量
if (map[i,j] == 2)
{
x = j;
y = i;
}
//遍历到3时,箱子的数目增加。boxs是前面定义的全局变量
if (map[i,j] == 3)
{
boxs++;
}
}
} } //在控制台上打印地图
public static void drawMap()
{
int i, j;
for (i = 0; i < WIDTH; i++)
{
for (j = 0; j < HEIGHT; j++)
{
switch (map[i,j])
{
case 0:
Console.Write(" ");
break;
case 1:
Console.Write("■");
break;
case 2:
Console.Write("♀");
break;
case 3:
Console.Write("◆");
break;
case 4:
Console.Write("●");
break;
case 5:
Console.Write("★");
break;
}
}
Console.Write("\n");
} } //向上移动
public static void moveUp()
{
int ux, uy; //当上方没有元素时,直接return (其实人不可能在边缘)
if (y == 0)
{
return;
} //记录上方坐标,x为横,y为纵,所有ux = x, uy = y - 1;
ux = x;
uy = y - 1; //上方为已完成的箱子
if (map[uy,ux] == 5)
{
return;
}
//假设上方为墙,直接return,这个和上面的判断可以合在一起,这里为了看清楚分开写
if (map[uy,ux] == 1)
{
return;
} //假设上方为箱子
if (map[uy,ux] == 3)
{
//判断箱子上方是否为墙
if (map[uy - 1,ux] == 1)
{
return;
} //判断箱子上方是否为终点
if (map[uy - 1,ux] == 4)
{
//将箱子上面内容赋值为5★
map[uy - 1,ux] = 5;
map[uy,ux] = 0; //箱子的数目减1
boxs--;
}
else
{
//移动箱子
map[uy - 1,ux] = 3;
}
}
//当上面几种return的情况都没遇到,人肯定会移动,移动操作如下
map[y,x] = 0;
map[uy,ux] = 2;
//更新人的坐标
y = uy; } //向左移动
public static void moveLeft()
{
int lx, ly; //当左边没有元素时,直接return
if (x == 0)
{
return;
} //记录左边坐标
lx = x - 1;
ly = y; //左边为已完成方块
if (map[ly,lx] == 5)
{
return;
} //假设左边为墙,直接return
if (map[ly,lx] == 1)
{
return;
} //假设左边为箱子
if (map[ly,lx] == 3)
{
//判断箱子左边是否为墙
if (map[ly,lx - 1] == 1)
{
return;
} //判断箱子左边是否为球
if (map[ly,lx - 1] == 4)
{
//将箱子左边内容赋值为5★
map[ly,lx - 1] = 5;
map[ly,lx] = 0; //箱子的数目减1
boxs--;
}
else
{
//移动箱子
map[ly,lx - 1] = 3;
}
}
map[y,x] = 0;
map[ly,lx] = 2;
x = lx; } //向下移动
public static void moveDown()
{
int dx, dy; //当下方没有元素时,直接return
if (y == HEIGHT - 1)
{
return;
} //记录下方坐标
dx = x;
dy = y + 1; //下方为已完成方块
if (map[dy,dx] == 5)
{
return;
} //假设下方为墙,直接return
if (map[dy,dx] == 1)
{
return;
} //假设下方为箱子
if (map[dy,dx] == 3)
{
//判断箱子下方是否为墙
if (map[dy + 1,dx] == 1)
{
return;
} //判断箱子下方是否为球
if (map[dy + 1,dx] == 4)
{
//将箱子下面内容赋值为5★
map[dy + 1,dx] = 5;
map[dy,dx] = 0; //箱子的数目减1
boxs--;
}
else
{
//移动箱子
map[dy + 1,dx] = 3;
}
}
map[y,x] = 0;
map[dy,dx] = 2;
y = dy; } //向右移动
public static void moveRight()
{
int rx, ry; //当右边没有元素时,直接return
if (x == WIDTH - 1)
{
return;
} //记录右边坐标
rx = x + 1;
ry = y; //右边为已完成方块
if (map[ry,rx] == 5)
{
return;
} //假设右边为墙,直接return
if (map[ry,rx] == 1)
{
return;
} //假设右边为箱子
if (map[ry,rx] == 3)
{
//判断箱子右边是否为墙
if (map[ry,rx + 1] == 1)
{
return;
} //判断箱子左边是否为球
if (map[ry,rx + 1] == 4)
{
//将箱子右边内容赋值为5★
map[ry,rx + 1] = 5;
map[ry,rx] = 0; //箱子的数目减1
boxs--;
}
else
{
//移动箱子
map[ry,rx + 1] = 3;
}
}
map[y,x] = 0;
map[ry,rx] = 2;
x = rx; } }
}

  

C#语言实现推箱子的更多相关文章

  1. C语言实现推箱子游戏完整代码

    C语言实现推箱子游戏完整代码 前言 自己做的,可能有些代码不够工整,或者有些小问题,但游戏的基本操作是可以实现的 代码效果 代码一共分为8个部分,4个控制上下左右移动,2个判断输赢,1个统计归为的个数 ...

  2. C语言之推箱子游戏代码

    前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:Yan_Less 正文 新手注意:如果你学习遇到问题找不到人解答,可以点 ...

  3. C/C++编程笔记:C语言写推箱子小游戏,大一学习C语言练手项目

    C语言,作为大多数人的第一门编程语言,重要性不言而喻,很多编程习惯,逻辑方式在此时就已经形成了.这个是我在大一学习 C语言 后写的推箱子小游戏,自己的逻辑能力得到了提升,在这里同大家分享这个推箱子小游 ...

  4. c语言游戏推箱子

    前两天做了推箱子小游戏,看似简单的一个小游戏背后却 有巨大的秘密,这秘密就是一大堆逻辑. 自从学习了函数过后,的确是解决了很多问题,而且调用很方便,尽管我现在都不是很会调用. 写完一个函数,准备测试一 ...

  5. C语言版推箱子

    推箱子源代码初步: #include<stdio.h> #include<conio.h> #include<stdlib.h> #define boolean i ...

  6. C语言小程序——推箱子(窄字符和宽字符)

    C语言小程序——推箱子(窄字符Version) 推箱子.c #include <stdio.h> #include <conio.h> #include <stdlib. ...

  7. 012-C语言小游戏之推箱子

    012-C语言小游戏之推箱子 一.创建游戏地图   1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 #define ROWS 11 #define COLS 12   char ...

  8. 每个人都可以用C语言写的推箱子小游戏!今天你就可以写出属于自己项目~

    C语言,作为大多数人的第一门编程语言,重要性不言而喻,很多编程习惯,逻辑方式在此时就已经形成了.这个是我在大一学习 C语言 后写的推箱子小游戏,自己的逻辑能力得到了提升,在这里同大家分享这个推箱子小游 ...

  9. 完整版本的推箱子小游戏,最简单的纯C语言打造

    /* 推箱子小游戏 1.定义绘制样式 用二维数组的方式 2.绘制图像 3.找出当前位置 4.逻辑判断,制造动作 根据数学xy轴的规律,这里使用ij 上移,行轴上升,行数减少 下移,行数下降,函数增加 ...

随机推荐

  1. 如何在Ubuntu 18.04上安装Nginx

    Nginx功能之强大,想必大家比我更清楚. 百度百科:Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务.Nginx是由伊戈尔 ...

  2. 详解 Set接口

    (请关注 本人"集合"总集篇博文--<详解 Collection接口>) 在Collection接口的子接口中,最重要的,也是最常见的两个-- List接口 和 Set ...

  3. Everything信息泄露

    Everything漏洞描述 [Everything]一款搜索文件非常快的工具,其速度之快令人震惊!它还有一个可以通过HTTP 或 FTP 分享搜索结果 的功能.它可以让用户在本地或局域网上的其他电脑 ...

  4. 被折磨致死的heroku——herku部署

    最近一直在弄heroku部署上线,但是因为中国墙和英语问题,一直弄不好,,很是烦躁,所有暂时先放弃了,但是因为查询了一些资料,有些文档链接有必要放到下面,方便各位和自己查看: heroku官方网站: ...

  5. Redis的三大问题

    一般我们对缓存读操作的时候有这么一个固定的套路: 如果我们的数据在缓存里边有,那么就直接取缓存的. 如果缓存里没有我们想要的数据,我们会先去查询数据库,然后将数据库查出来的数据写到缓存中. 最后将数据 ...

  6. 模拟电磁曲射炮_H题 方案分析【2019年电赛】【刘新宇qq522414928】

    请查看我的有道云笔记: 文档:电磁曲射炮分析.note链接:http://note.youdao.com/noteshare?id=26f6b6febc04a8983d5efce925e92e21

  7. Jmeter与LoadRunner的比较

    一.与Loadrunner的比较相似点 1.Jmeter的架构跟loadrunner原理一样, 都是通过中间代理,监控&收集并发客户端发现的指令,把他们生成脚本,再发送到应用服务器,再监控服务 ...

  8. 编程语言千千万,为什么学习Python的占一半?

    如果让你从数百种的编程语言中选择一个入门语言?你会选择哪一个? 是应用率最高.长期霸占排行榜的常青藤 Java?是易于上手,难以精通的 C?还是在游戏和工具领域仍占主流地位的 C++?亦或是占据 Wi ...

  9. 怎么在java中创建一个自定义的collector

    目录 简介 Collector介绍 自定义Collector 总结 怎么在java中创建一个自定义的collector 简介 在之前的java collectors文章里面,我们讲到了stream的c ...

  10. SaltStack的数据系统

    一.SaltStack数据系统的分类 1.Grains(收集的是静态数据) 官方使用文档:https://www.unixhot.com/docs/saltstack/topics/targeting ...