首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

纯C语言写的编程小游戏——最炫酷推箱子

很多编程爱好者都编写过推箱子游戏编程吧,最近有好些朋友看见我以前的推箱子程序后,

C语言是面向过程的,而C++是面向对象的

C和C++的区别:

C是一个结构化语言,它的重点在于算法和数据结构。C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到输出(或实现过程(事务)控制)。

C++,首要考虑的是如何构造一个对象模型,让这个模型能够契合与之对应的问题域,这样就可以通过获取对象的状态信息得到输出或实现过程(事务)控制。 所以C与C++的最大区别在于它们的用于解决问题的思想方法不一样。之所以说C++比C更先进,是因为“ 设计这个概念已经被融入到C++之中 ”。

C与C++的最大区别:在于它们的用于解决问题的思想方法不一样。之所以说C++比C更先进,是因为“ 设计这个概念已经被融入到C++之中 ”,而就语言本身而言,在C中更多的是算法的概念。那么是不是C就不重要了,错!算法是程序设计的基础,好的设计如果没有好的算法,一样不行。而且,“C加上好的设计”也能写出非常好的东西。 问我是怎么做的。我一直想把这个程序的整个过程写一份详细的东西,与各位编程爱好者分享,一直没空。正好现在放假了,而且离回家还有几天。于是我就把这个程序重新写了一遍,尽量使程序的结构比较清晰好懂一些。同时写了下面的这份东西。

零基础小白到大神之路,欢迎加学习裙 三四一六三流七二七裙里有免费c/c++课程,还有大量干货哦

通过w,s,a,d实现上下左右的移动

声明画图函数

然后分别对移动位置进行情况判断:

1.如果人前面是空地。

2.如果人前面是目的地。

3.如果人前面是箱子。有以下两种情况:

如果人前面是箱子,而箱子前面是空地。

如果人的前面是箱子,而箱子前面是目的地。

4.如果人前面是已经进入某目的地的箱子。有以下两种情况:

如果人前面是已经进入某目的地的箱子,而箱子前面是空地。

如果人前面是已经进入某目的地的箱子,而箱子前面是另一目的地。

5.对箱子原先位置的判断。

6.对人原先位置进行判断。

【从百科上参考查阅下载的代码,并加以整理】

[cpp] view plain copy

//此小游戏使用C语言编写,编译环境VS2008

#include

#include

#include

int i,j;

void draw_map(int map[10][12]); //声明画图函数

int main()

{

char input;

int count=0; //定义记分变量

/*下面定义一个二维数组,其中的元素是不同图像的ID号,在后面的函数中将讲解不同数字分别代表的图像元素*/

int map[10][12] = {

while (1) //死循环,等待用户命令

{

system("CLS");

for (i=0;i

{

printf("%d",i);

}

printf(" ");

/*for (i=1;i

{

printf("%d ",i);

}*/

printf(" ");

draw_map(map);

printf("当前得分:%d ",count);

//找初始位置

for (i=0;i

{

for (j=0;j

{

if (map[i][j]==6||map[i][j]==9)

break;

}

if (map[i][j]==6||map[i][j]==9)

break;

}

printf("您的当前坐标(%d,%d)",i,j);

input = getch(); //用getch()函数无需回车确认地获取用户输入,用于控制行走方向。

switch (input)

{

case'w':

//如果人前面是空地。 //0代表空地 6代表人 //3代表目的地

if(map[i-1][j]==0)

{

map[i-1][j]=6+0; //人往前走一步,ID为人的ID()加上空地的ID()。

if(map[i][j]==9) //如果当前人站的位置为目的地,则ID为(即人的ID()加上目的地ID())。

map[i][j]=3; //将人往前走一步后原地的ID修改为空地ID()。

else

map[i][j]=0; //否则原地ID修改为空地ID 。

}

//如果人前面是目的地。

elseif((map[i-1][j]==3)||(map[i-1][j]==9))

{

map[i-1][j]=6+3; //人往前走一步,ID为人ID+目的地ID=9。

if(map[i][j]==9) //如果原地也是目的地(ID为)。

map[i][j]=3; //人走后把原地ID修改回目的地ID。

else

map[i][j]=0; //否则原地ID修改为为空地ID

}

//如果人前面是箱子。//4代表箱子 //7箱子进入目的地

elseif(map[i-1][j]==4)

{

//如果人前面是箱子,而箱子前面是空地。

if (map[i-2][j]==0)

{

map[i-2][j]=4; //人推箱子往前走一步,把空地ID修改为箱子ID()

//下面是对箱子原地进行判断

if(map[i-1][j]==7) //如果箱子原地为目的地。

map[i-1][j]=9; //人站在箱子的原地(目的地)时该地ID应该为人的ID+目的地ID=9。

else

map[i-1][j]=6; //否则,人站在了原来的空地上,ID应该为+0=6。

//下面是对人原地进行判断

if(map[i][j]==9) //如果之前是目的地。

map[i][j]=3; //人走了之后修改回目的地ID。

else

map[i][j]=0; //否则就是空地。

}

//如果人的前面是箱子,而箱子前面是目的地。

elseif (map[i-2][j]==3)

{

map[i-2][j]=7; //ID为(目的地ID()+箱子ID()=7),表示已经把箱子推入了目的地。

count++;

//下面是对箱子原先位置的判断,同上。

if(map[i-1][j]==7)

map[i-1][j]=9;

else

map[i-1][j]=6;

//下面是对人原先位置进行判断,同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

}

//如果人前面是已经进入某目的地的箱子(ID=7)。

elseif(map[i-1][j]==7)

{

//如果人前面是已经进入某目的地的箱子,而箱子前面是空地。

if(map[i-2][j]==0)

{

count--;

map[i-2][j]=4; //把箱子重新推到空地上,ID=箱子ID+空地ID=4。

map[i-1][j]=9; //人自然而然的就站在了原先的目的地上了。

//下面是对人原先地进行判断,方法同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

//如果人前面是已经进入某目的地的箱子,而箱子前面是另一目的地。

if(map[i-2][j]==3)

{

map[i-2][j]=7; //把箱子推入了另一目的地,自然,ID也应是。

map[i-1][j]=9; //人站在了目的地上。

//下面是对人原先站立地进行判断,方法同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

}

break;

case's':

//如果人前面是空地。

if(map[i+1][j]==0)

{

map[i+1][j]=6+0; //人往前走一步,ID为人的ID()加上空地的ID()。

if(map[i][j]==9) //如果当前人站的位置为目的地,则ID为(即人的ID()加上目的地ID())。

map[i][j]=3; //将人往前走一步后原地的ID修改为空地ID()。

else

map[i][j]=0; //否则原地ID修改为空地ID 。

}

//如果人前面是目的地。

elseif(map[i+1][j]==3)

{

map[i+1][j]=6+3; //人往前走一步,ID为人ID+目的地ID=9。

if(map[i][j]==9) //如果原地也是目的地(ID为)。

map[i][j]=3; //人走后把原地ID修改回目的地ID。

else

map[i][j]=0; //否则原地ID修改为为空地ID

}

//如果人前面是箱子。

elseif(map[i+1][j]==4)

{

//如果人前面是箱子,而箱子前面是空地。

if (map[i+2][j]==0)

{

map[i+2][j]=4; //人推箱子往前走一步,把空地ID修改为箱子ID()

//下面是对箱子原地进行判断

if(map[i+1][j]==7) //如果箱子原地为目的地。

map[i+1][j]=9; //人站在箱子的原地(目的地)时该地ID应该为人的ID+目的地ID=9。

else

map[i+1][j]=6; //否则,人站在了原来的空地上,ID应该为+0=6。

//下面是对人原地进行判断

if(map[i][j]==9) //如果之前是目的地。

map[i][j]=3; //人走了之后修改回目的地ID。

else

map[i][j]=0; //否则就是空地。 (加群: 571545210 学习编程,在群里获得更多的学习资料)

}

//如果人的前面是箱子,而箱子前面是目的地。

elseif (map[i+2][j]==3)

{

map[i-2][j]=7; //ID为(目的地ID()+箱子ID()=7),表示已经把箱子推入了目的地。

count++;

//下面是对箱子原先位置的判断,同上。

if(map[i+1][j]==7)

map[i+1][j]=9;

else

map[i+1][j]=6;

//下面是对人原先位置进行判断,同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

}

//如果人前面是已经进入某目的地的箱子(ID=7)。

elseif(map[i+1][j]==7)

{

//如果人前面是已经进入某目的地的箱子,而箱子前面是空地。

if(map[i+2][j]==0)

{

count--;

map[i+2][j]=4; //把箱子重新推到空地上,ID=箱子ID+空地ID=4。

map[i+1][j]=9; //人自然而然的就站在了原先的目的地上了。

//下面是对人原先地进行判断,方法同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

//如果人前面是已经进入某目的地的箱子,而箱子前面是另一目的地。

if(map[i+2][j]==3)

{

map[i+2][j]=7; //把箱子推入了另一目的地,自然,ID也应是。

map[i+1][j]=9; //人站在了目的地上。

//下面是对人原先站立地进行判断,方法同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

}

break;

case'a':

//如果人前面是空地。

if(map[i][j-1]==0)

{

map[i][j-1]=6+0; //人往前走一步,ID为人的ID()加上空地的ID()。

if(map[i][j]==9) //如果当前人站的位置为目的地,则ID为(即人的ID()加上目的地ID())。

map[i][j]=3; //将人往前走一步后原地的ID修改为空地ID()。

else

map[i][j]=0; //否则原地ID修改为空地ID 。

}

//如果人前面是目的地。

elseif(map[i][j-1]==3)

{

map[i][j-1]=6+3; //人往前走一步,ID为人ID+目的地ID=9。

if(map[i][j]==9) //如果原地也是目的地(ID为)。

map[i][j]=3; //人走后把原地ID修改回目的地ID。

else

map[i][j]=0; //否则原地ID修改为为空地ID

}

//如果人前面是箱子。

elseif(map[i][j-1]==4)

{

//如果人前面是箱子,而箱子前面是空地。

if (map[i][j-2]==0)

{

map[i][j-2]=4; //人推箱子往前走一步,把空地ID修改为箱子ID()

//下面是对箱子原地进行判断

if(map[i][j-1]==7) //如果箱子原地为目的地。

map[i][j-1]=9; //人站在箱子的原地(目的地)时该地ID应该为人的ID+目的地ID=9。

else

map[i][j-1]=6; //否则,人站在了原来的空地上,ID应该为+0=6。

//下面是对人原地进行判断

if(map[i][j]==9) //如果之前是目的地。

map[i][j]=3; //人走了之后修改回目的地ID。

else

map[i][j]=0; //否则就是空地。

}

//如果人的前面是箱子,而箱子前面是目的地。

elseif (map[i][j-2]==3)

{

count++;

map[i][j-2]=7; //ID为(目的地ID()+箱子ID()=7),表示已经把箱子推入了目的地。

//下面是对箱子原先位置的判断,同上。

if(map[i][j-1]==7)

map[i][j-1]=9;

else

map[i][j-1]=6;

//下面是对人原先位置进行判断,同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

}

//如果人前面是已经进入某目的地的箱子(ID=7)。

elseif(map[i][j-1]==7)

{

//如果人前面是已经进入某目的地的箱子,而箱子前面是空地。

if(map[i][j-2]==0)

{

count--;

map[i][j-2]=4; //把箱子重新推到空地上,ID=箱子ID+空地ID=4。

map[i][j-1]=9; //人自然而然的就站在了原先的目的地上了。

//下面是对人原先地进行判断,方法同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

//如果人前面是已经进入某目的地的箱子,而箱子前面是另一目的地。

if(map[i][j-2]==3)

{

map[i][j-2]=7; //把箱子推入了另一目的地,自然,ID也应是。

map[i][j-1]=9; //人站在了目的地上。

//下面是对人原先站立地进行判断,方法同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

}

break;

case'd':

//如果人前面是空地。

if(map[i][j+1]==0)

{

map[i][j+1]=6+0; //人往前走一步,ID为人的ID()加上空地的ID()。

if(map[i][j]==9) //如果当前人站的位置为目的地,则ID为(即人的ID()加上目的地ID())。

map[i][j]=3; //将人往前走一步后原地的ID修改为空地ID()。

else

map[i][j]=0; //否则原地ID修改为空地ID 。

}

//如果人前面是目的地。

elseif(map[i][j+1]==3)

{

map[i][j+1]=6+3; //人往前走一步,ID为人ID+目的地ID=9。

if(map[i][j]==9) //如果原地也是目的地(ID为)。

map[i][j]=3; //人走后把原地ID修改回目的地ID。

else

map[i][j]=0; //否则原地ID修改为为空地ID

}

//如果人前面是箱子。

elseif(map[i][j+1]==4)

{

//如果人前面是箱子,而箱子前面是空地。

if (map[i][j+2]==0)

{

map[i][j+2]=4; //人推箱子往前走一步,把空地ID修改为箱子ID()

//下面是对箱子原地进行判断

if(map[i][j+1]==7) //如果箱子原地为目的地。

map[i][j+1]=9; //人站在箱子的原地(目的地)时该地ID应该为人的ID+目的地ID=9。

else

map[i][j+1]=6; //否则,人站在了原来的空地上,ID应该为+0=6。

//下面是对人原地进行判断

if(map[i][j]==9) //如果之前是目的地。

map[i][j]=3; //人走了之后修改回目的地ID。

else

map[i][j]=0; //否则就是空地。

}

//如果人的前面是箱子,而箱子前面是目的地。

elseif (map[i][j+2]==3)

{

count++;

map[i][j+2]=7; //ID为(目的地ID()+箱子ID()=7),表示已经把箱子推入了目的地。

//下面是对箱子原先位置的判断,同上。

if(map[i][j+1]==7)

map[i][j+1]=9;

else

map[i][j+1]=6;

//下面是对人原先位置进行判断,同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

}

//如果人前面是已经进入某目的地的箱子(ID=7)。

elseif(map[i][j+1]==7)

{

//如果人前面是已经进入某目的地的箱子,而箱子前面是空地。

if(map[i][j+2]==0)

{

count--;

map[i][j+2]=4; //把箱子重新推到空地上,ID=箱子ID+空地ID=4。

map[i][j+1]=9; //人自然而然的就站在了原先的目的地上了。

//下面是对人原先地进行判断,方法同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

//如果人前面是已经进入某目的地的箱子,而箱子前面是另一目的地。

if(map[i][j+2]==3)

{

map[i][j+2]=7; //把箱子推入了另一目的地,自然,ID也应是。

map[i][j+1]=9; //人站在了目的地上。

//下面是对人原先站立地进行判断,方法同上。

if(map[i][j]==9)

map[i][j]=3;

else

map[i][j]=0;

}

}

break;

}

if(count==8) //如果分数达到分

{

system("CLS"); //清屏

draw_map(map);

break; //退出死循环

}

}

printf(" 恭喜你,过关了!! "); //过关提示

return 0;

}

void draw_map(int map[10][12])

{

for(i=0;i

{

for(j=0;j

{

switch(map[i][j])

{

case 0:

printf(" "); //数字代表道路

break;

case 1:

printf("#"); //数字代表墙壁

break;

case 2:

printf(" "); //数字是游戏边框的空白部分

break;

case 3:

printf("!"); //数字代表目的地

break;

case 4:

printf("*"); //数字代表箱子

break;

case 7:

printf("$"); //数字代表箱子进入目的地

break;

case 6:

printf("@"); //数字代表人

break;

case 9:

printf("@"); //数字代表人进入目的地

break;

}

}

printf(" "); //分行输出

}

}

零基础小白到大神之路,欢迎加学习裙 三四一六三流七二七裙里有免费c/c++课程,还有大量干货哦

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20171224A09HG000?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券