C++推箱子小游戏

感谢Lo问我为什么看星星大佬(粉丝比我少)的帮助!

推箱子就是主角将箱子通过移动推到指定地点的游戏

今天,我们用C++来还原一下这款游戏

首先我们要定义地图,地图多大都可以

但是最好使用整数类型,这样运行起来容易,但是我为了美观,还是使用了字符类型

char a[11][11]={
	"##########",
	"##      ##",
	"## ## N ##",
	"# o      #",
	"# # ###  #",
	"###  #x  #",
	"##########"
};

注意,因为源代码有错误,需要加上分号,删除最后的逗号,不然无法成立,地图范围不超过10,不能设置10,以防有意外,而且这样不好判断是否走到死角

然后呢我们定义字符变量b用来接收输入的方向

char b;

定义位置为X=3,Y=2,然后定义变量,这两个要倒着来,不然会错误

int x = 3, y = 2;

然后呢打印欢迎语,这里我改进了一下,因为cin和cout的实际速度是比scanf和printf速度慢的(真实),然后窗口要定义名字,这就需要了另一个函数库

#include <windows.h>

这样就可以了,然后怎么更改窗口名字

这很简单

system("title 推箱子小游戏");

最好放在前面,然后打印欢迎语,再等待5秒

可能会有人疑惑,C++怎么等待5秒

这很简单

Sleep(5000);

然后切换界面,清空文字,设置文字颜色为XX色(什么色都可以)

清空文字也简单

system("cls");

设置文字这里要说一下,system函数的性质其实和我们大多数人使用的Windows系统中的命令提示符(Cmd)一模一样

所以我这里要声明一点

COLOR [attr]

  attr        指定控制台输出的颜色属性。

颜色属性由两个十六进制数字指定 -- 第一个
对应于背景,第二个对应于前景。每个数字
可以为以下任何值:

    0 = 黑色       8 = 灰色
    1 = 蓝色       9 = 淡蓝色
    2 = 绿色       A = 淡绿色
    3 = 浅绿色     B = 淡浅绿色
    4 = 红色       C = 淡红色
    5 = 紫色       D = 淡紫色
    6 = 黄色       E = 淡黄色
    7 = 白色       F = 亮白色

然后我们定义颜色

system("color 06");

我这里定义了黄色

然后无限循环

再次清空文字

然后for循环10次,因为地图就这么大,然后用puts打印a列表,这样做是打印地图

其实也可以用printf,但是要麻烦一点

但是说实话puts是不大稳定的

用puts的话需要用到新函数库

#include <conio.h>
#include <cstring>

两个哪一个都行

for(int i = 0; i < 10; i++) 
{
	puts(a[i]);
}

然后打印提示语

printf("你是‘o’,你要把箱子(‘N’)推到放箱子的地点(‘x’)!");
printf("往上按‘w’,往下按‘s’,往左按‘a’,往右按‘d’,请用英文输入!");

然后开始接收输入的方向(W前,S后,A左,D右)

b = getch();

然后再移动主角前进方向,再判断如果碰到箱子和碰到X和碰到边界的反应

if(b == 'w') {
			if(a[x - 1][y] != '#') 
			{
				if(a[x - 1][y] == 'N') 
				{
					if(a[x - 2][y] != '#') 
					{
						a[x - 2][y] = 'N';
						a[x][y] = ' ';
						x--;
						a[x][y] = 'o';
					}
				}
				else 
				{
					a[x][y] = ' ';
					x--;
					a[x][y] = 'o';
				}
			}
		}

再判断主角后退方向

if(b == 's') {
			if(a[x + 1][y] != '#') {
				if(a[x + 1][y] == 'N') {
					if(a[x + 2][y] != '#') {
						a[x + 2][y] = 'N';
						a[x][y] = ' ';
						x++;
						a[x][y] = 'o';
					}
				}
				else {
					a[x][y] = ' ';
					x++;
					a[x][y] = 'o';
				}
			}
		}

再判断主角左走方向

if(b == 'a') {
			if(a[x][y - 1] != '#') {
				if(a[x][y - 1] == 'N') {
					if(a[x][y - 2] != '#') {
						a[x][y - 2] = 'N';
						a[x][y] = ' ';
						y--;
						a[x][y] = 'o';
					}
				}
				else {
					a[x][y] = ' ';
					y--;
					a[x][y] = 'o';
				}
			}
		}

再判断主角右走方向

if(b == 'd') {
			if(a[x][y + 1] != '#') {
				if(a[x][y + 1] == 'N') {
					if(a[x][y + 2] != '#') {
						a[x][y + 2] = 'N';
						a[x][y] = ' ';
						y++;
						a[x][y] = 'o';
					}
				}
				else {
					a[x][y] = ' ';
					y++;
					a[x][y] = 'o';
				}
			}
		}

判断地点是否存在

if(a[5][6] == ' ')
{
    a[5][6]='x';
}

如果箱子推进去则挑战成功

if(a[5][6] == 'N') {
			system("cls");
			system("color 07");
			cout << "恭喜你挑战成功!" << endl;
			
			getch();
			return 0;
		}

最重要的一点来了,判断箱子是否到达了死角

for(int i = 0; i < 10; i++) {
			for(int j = 0; j < 10; j++) {
				if(a[i][j] == 'N') {
					if(a[i - 1][j] == '#' && a[i][j + 1] == '#') {
						system("cls");
						
						for(int i = 0; i < 10; i++) puts(a[i]);
						
						Sleep(3000);
						system("cls");
						system("color 07");
						cout << "你输了,箱子进入了死角!" << endl;
						
						getch();
						return 0;
					}
					
					if(a[i - 1][j] == '#' && a[i][j - 1] == '#') {
						system("cls");
						
						for(int i = 0; i < 10; i++) puts(a[i]);
						
						Sleep(3000);
						system("cls");
						system("color 07");
						cout << "你输了,箱子进入了死角!" << endl;
						
						getch();
						return 0;
					}
					
					if(a[i + 1][j] == '#' && a[i][j - 1] == '#') {
						system("cls");
						
						for(int i = 0; i < 10; i++) puts(a[i]);
						
						Sleep(3000);
						system("cls");
						system("color 07");
						cout << "你输了,箱子进入了死角!" << endl;
						
						getch();
						return 0;
					}
					
					if(a[i + 1][j] == '#' && a[i][j + 1] == '#') {
						system("cls");
						
						for(int i = 0; i < 10; i++) puts(a[i]);
						
						Sleep(3000);
						system("cls");
						system("color 07");
						cout << "你输了,箱子进入了死角!" << endl;
						
						getch();
						return 0;
					}
				}
			}
		}

如果实在不想要的话,可以判断输入的是否为“q”,然后结束重来

最后结束

总代码

#include <iostream>
#include <cstring>
#include <windows.h>
#include <conio.h>
#include<cstdio>
using namespace std;
 
char a[11][11]={
	"##########",
	"##      ##",
	"## ## N ##",
	"# o      #",
	"# # ###  #",
	"###  #x  #",
	"##########"
};
int main()
{
	system("title 推箱子小游戏");
	char b;
	int x = 3, y = 2;
	cout << "欢迎来到推箱子游戏!(5秒后开始游戏!)" << endl;
	Sleep(5000);
	system("cls");
	system("color 06");
	
	while(true) {
		system("cls");
		for(int i = 0; i < 10; i++) 
		{
			puts(a[i]);
		}
		printf("你是‘o’,你要把箱子(‘N’)推到放箱子的地点(‘x’)!");//往上按‘w’,往下按‘s’,往左按‘a’,往右按‘d’,请用英文输入!
		printf("往上按‘w’,往下按‘s’,往左按‘a’,往右按‘d’,请用英文输入!");
		b = getch();
		if(b == 'w') {
			if(a[x - 1][y] != '#') 
			{
				if(a[x - 1][y] == 'N') 
				{
					if(a[x - 2][y] != '#') 
					{
						a[x - 2][y] = 'N';
						a[x][y] = ' ';
						x--;
						a[x][y] = 'o';
					}
				}
				else 
				{
					a[x][y] = ' ';
					x--;
					a[x][y] = 'o';
				}
			}
		}
		
		if(b == 's') {
			if(a[x + 1][y] != '#') {
				if(a[x + 1][y] == 'N') {
					if(a[x + 2][y] != '#') {
						a[x + 2][y] = 'N';
						a[x][y] = ' ';
						x++;
						a[x][y] = 'o';
					}
				}
				else {
					a[x][y] = ' ';
					x++;
					a[x][y] = 'o';
				}
			}
		}
		
		if(b == 'a') {
			if(a[x][y - 1] != '#') {
				if(a[x][y - 1] == 'N') {
					if(a[x][y - 2] != '#') {
						a[x][y - 2] = 'N';
						a[x][y] = ' ';
						y--;
						a[x][y] = 'o';
					}
				}
				else {
					a[x][y] = ' ';
					y--;
					a[x][y] = 'o';
				}
			}
		}
		
		if(b == 'd') {
			if(a[x][y + 1] != '#') {
				if(a[x][y + 1] == 'N') {
					if(a[x][y + 2] != '#') {
						a[x][y + 2] = 'N';
						a[x][y] = ' ';
						y++;
						a[x][y] = 'o';
					}
				}
				else {
					a[x][y] = ' ';
					y++;
					a[x][y] = 'o';
				}
			}
		}
		
		if(a[5][6] == ' ') a[5][6]='x';
		
		if(a[5][6] == 'N') {
			system("cls");
			system("color 07");
			cout << "恭喜你挑战成功!" << endl;
			
			getch();
			return 0;
		}
		
		for(int i = 0; i < 10; i++) {
			for(int j = 0; j < 10; j++) {
				if(a[i][j] == 'N') {
					if(a[i - 1][j] == '#' && a[i][j + 1] == '#') {
						system("cls");
						
						for(int i = 0; i < 10; i++) puts(a[i]);
						
						Sleep(3000);
						system("cls");
						system("color 07");
						cout << "你输了,箱子进入了死角!" << endl;
						
						getch();
						return 0;
					}
					
					if(a[i - 1][j] == '#' && a[i][j - 1] == '#') {
						system("cls");
						
						for(int i = 0; i < 10; i++) puts(a[i]);
						
						Sleep(3000);
						system("cls");
						system("color 07");
						cout << "你输了,箱子进入了死角!" << endl;
						
						getch();
						return 0;
					}
					
					if(a[i + 1][j] == '#' && a[i][j - 1] == '#') {
						system("cls");
						
						for(int i = 0; i < 10; i++) puts(a[i]);
						
						Sleep(3000);
						system("cls");
						system("color 07");
						cout << "你输了,箱子进入了死角!" << endl;
						
						getch();
						return 0;
					}
					
					if(a[i + 1][j] == '#' && a[i][j + 1] == '#') {
						system("cls");
						
						for(int i = 0; i < 10; i++) puts(a[i]);
						
						Sleep(3000);
						system("cls");
						system("color 07");
						cout << "你输了,箱子进入了死角!" << endl;
						
						getch();
						return 0;
					}
				}
			}
		}
	}
	
	return 0;
}

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值