本节便是贪吃蛇程序的最终部分,实现吃食物增加长度的功能,当二维数组canvas[High][Width]的元素值为-2时输出食物数值‘F’。

其实现思路和3.4.2节中小蛇的移动类似,只需保持原蛇尾,不将最大值变为0即可。

先奉上完整的代码:

#include<stdio.h>
#include<stdlib.h>
#include<conio.h>
#include<windows.h>#define High 20               //游戏画面尺寸
#define Width 30
//全局变量
int moveDirection;            //小蛇移动的方向,上、下、左、右分别用1、2、3、4表示
int food_x,food_y;            //食物的位置
int canvas[High][Width]={0};  //二维数组存储游戏画布中对应的元素 //0 为空格,-1为边框#,1为蛇头@,大于1的正数为蛇身* void gotoxy(int x,int y)     //将光标移动到(x,y)位置
{HANDLE handle =GetStdHandle(STD_OUTPUT_HANDLE);COORD pos;pos.X=x;pos.Y=y;SetConsoleCursorPosition(handle,pos);
}//下面的moveSnakeByDirection()函数用来实现移动小蛇
//第一步扫描数组canvas的所有元素,找到正数元素都加 1
//找到最大元素(即蛇尾巴),把其变为 0
//找到等于 2 的元素(即蛇头),根据输出的上下左右方向把对应的另一个像素值设为 1(新蛇头)
void moveSnakeByDirection()
{int i,j;for(i=1;i<High-1;i++)for(j=1;j<Width-1;j++)if(canvas[i][j]>0)canvas[i][j]++;int oldTail_i,oldTail_j,oldHead_i,oldHead_j;int max=0;for(i=1;i<High-1;i++)for(j=1;j<Width-1;j++)if(canvas[i][j]>0){if(max<canvas[i][j]){max=canvas[i][j];oldTail_i=i;oldTail_j=j;}if(canvas[i][j]==2){oldHead_i=i;oldHead_j=j;}}int newHead_i,newHead_j;      //定义一个数组用来存放新蛇头的数据 if(moveDirection==1)          //向上移动 {newHead_i=oldHead_i-1;    // i-1 是因为向上移动因此新蛇头的位置向上移 newHead_j=oldHead_j;      //因为是竖直方向的运动并不影响左右 }if(moveDirection==2)          //向下移动 {newHead_i=oldHead_i+1;    // i+1 是因为向下移动因此新蛇头的位置向下移 newHead_j=oldHead_j;      //因为是竖直方向的运动并不影响左右}if(moveDirection==3)         //向左移动 {newHead_i=oldHead_i;     //因为是左右方向的运动并不影响竖直方向 newHead_j=oldHead_j-1;   // j-1 是因为向左移动,因此新蛇头的位置向左移动 }if(moveDirection==4)         //向右移动 {newHead_i=oldHead_i;     //因为是左右方向的运动并不影响竖直方向 newHead_j=oldHead_j+1;   // j-1 是因为向右移动,因此新蛇头的位置向右移动 }//如果新蛇头吃到食物if(canvas[newHead_i][newHead_j]==-2){canvas[food_x][food_y]=0;//产生一个新的食物food_x=rand()%(High-5)+2;food_y=rand()%(Width-5)+2;canvas[food_x][food_y]=-2;//原本的旧蛇尾留着,长度自动加 1 }else                            //否则,原来的旧蛇尾减掉,保持长度不变canvas[oldTail_i][oldTail_j]=0;// 小蛇是否和自身撞或者边框,游戏失败if(canvas[newHead_i][newHead_j]>0||canvas[newHead_i][newHead_j]==-1){printf("游戏失败!\n");Sleep(2000);system("pause");exit(0);}elsecanvas[newHead_i][newHead_j]=1;
}void startup()
{int i,j;//初始化边框for(i=0;i<High;i++){canvas[i][0]=-1;canvas[i][Width-1]=-1;}for(j=0;j<Width;j++){canvas[0][j]=-1;canvas[High-1][j]=-1;}//初始化蛇头位置 canvas[High/2][Width/2]=1;  //初始化蛇身,画布中的元素值分别为2、3、4、5等 for(i=1;i<=4;i++)canvas[High/2][Width/2-i]=i+1;//初始化小蛇向右移动   moveDirection=4;food_x=rand()%(High-5)+2;food_y=rand()%(Width-5)+2;canvas[food_x][food_y]=-2;
}void show()                 //显示画面
{gotoxy(0,0);            //光标移动到原点位置,以下重画清屏 int i,j;for(i=0;i<High;i++){for(j=0;j<Width;j++){if(canvas[i][j]==0)printf(" ");     //输出空格 else if(canvas[i][j]==-1)printf("#");     //输出边框# else if(canvas[i][j]==1)printf("@");     //输出蛇头@ else if(canvas[i][j]>1)printf("*");     //输出蛇身* else if(canvas[i][j]==-2)printf("F");     //输出食物 F}printf("\n");}Sleep(100);
}void updateWithoutInput()       //与用户输入无关的更新
{moveSnakeByDirection();
}void updateWithInput()          //与用户输入有关的更新
{char input;if(kbhit())                 //判断是否有输入 {input=getch();          //根据用户的不同输入来移动,不必输入回车 if(input=='a'){moveDirection=3;    //位置左移 moveSnakeByDirection();}else if(input=='d'){moveDirection=4;    //位置右移 moveSnakeByDirection();}else if(input=='w'){moveDirection=1;   //位置上移 moveSnakeByDirection();}else if(input=='s'){moveDirection=2;  //位置下移 moveSnakeByDirection();}}
}int main()
{startup();                  //数据的初始化 while(1)                    //游戏循环执行 {show();                 //显示画面 updateWithoutInput();   //与用户输入无关的更新 updateWithInput();      //与用户输入有关的更新 }return 0;
} 

通过之前的学习相信都能对整个代码有了理解和掌握。

老规矩这次依然指出一些需要注意和理解的地方:

food_x=rand()%(High-5)+2;
food_y=rand()%(Width-5)+2;

首先要了解 rand()函数 的用法,举个例子:

rand()%100  代表的意思是从0~99里面随机出现一个数字。

因此 rand()%100+1  代表的意思是从1~10里面随机出现的一个数字。

故上述代码可以保证食物的”行数“和”列数“可以随机生成,从而保证食物的位置随机生成。

明白这些相信对完整的代码有更深的理解和掌握。

复现贪吃蛇程序——吃食物增加长度(最后一篇)相关推荐

  1. 贪吃蛇程序(金沙滩51单片机)-启动篇-1(含演示GIF)

    点击获取工程源码 首先声明:本代码中不含中断程序(因为当时没学,后来觉得51过于落伍,故没有深学),以下的代码只是挑出其中主要的进行细讲,源码点击上方获取. 我们将启动贪吃蛇分为以下5个步骤: 1.初 ...

  2. 复现贪吃蛇程序——构造小蛇

    要求: 在画面中显示一条静止的小蛇.对于二维数组canvas[High][Width]的对应元素,值为0输出空格,值为-1输出边框#,值为1输出蛇头@,值为大于1的正数输出蛇身*.在startup() ...

  3. 【python教程入门学习】Python实现自动玩贪吃蛇程序

    这篇文章主要介绍了通过Python实现的简易的自动玩贪吃蛇游戏的小程序,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学一学 实现效果 先看看效果 这比我手动的快多了,而且是单机的,自动玩没惹 ...

  4. c语言中怎么暂停一个一个游戏,求助:最近在linux下用c语言写了一个贪吃蛇程序,有几个问题,第一:贪吃蛇怎么实现暂停,第二:有时候同时输入上下左右中的两个键就会直接游戏结束...

    求助:最近在linux下用c语言写了一个贪吃蛇程序,有几个问题,第一:贪吃蛇怎么实现暂停,第二:有时候同时输入上下左右中的两个键就会直接游戏结束 /* 以下是主要的逻辑代码,还有些.c和.h就没发了 ...

  5. JAVA小程序:一个基于MVC框架的贪吃蛇程序

    学习JAVA也有一段时间了,之前看了翁恺老师的视频,跟着做了一个细胞自动机,粗浅地了解了一点MVC框架的知识,感觉获益匪浅.但是细胞自动机毕竟是跟着视频完成的,有很大程度上都是参考了视频里的代码,没有 ...

  6. 超赞的贪吃蛇、吃豆人和数字华容道等童年小游戏1行Python代码就能玩

    今天分享一个有趣的Python游戏库freegames,它包含20余款经典小游戏,像贪吃蛇.吃豆人.乒乓.数字华容道等等,依托于标准库Turtle. 我们不仅可以通过1行代码进行重温这些童年小游戏,还 ...

  7. 超赞!贪吃蛇、吃豆人和数字华容道等童年小游戏1行Python代码就能玩

    大家好,我是才哥. 今天分享一个有趣的Python游戏库freegames,它包含20余款经典小游戏,像贪吃蛇.吃豆人.乒乓.数字华容道等等,依托于标准库Turtle. 我们不仅可以通过1行代码进行重 ...

  8. 用python写一个贪吃蛇程序

    我可以为您提供一些有关如何使用Python编写贪吃蛇程序的指导.首先,您需要确定您的程序所需的功能,以及游戏的规则和特性.接下来,您可以编写代码来实现这些功能,并使用Python的图形库来绘制游戏界面 ...

  9. Swing贪吃蛇游戏(四):增加游戏得分排行榜功能

    在上几篇博文中,介绍了 Swing贪吃蛇游戏(一):基本功能实现 >>> [url]http://mouselearnjava.iteye.com/blog/1913290[/url ...

  10. 模仿别人的简单贪吃蛇程序

    参考的别人的贪吃蛇程序,只做了少许的更改,惭愧.http://bbs.csdn.net/topics/350080780 #include <stdio.h> #include <s ...

最新文章

  1. 为什么平头哥做芯片如此迅猛?
  2. Oracle数据类型(转)
  3. 天马行空W:在C++中调用DLL中的函数
  4. Plyr – 简单,灵活的 HTML5 媒体播放器
  5. 大学生计算机python_非计算机专业的大学生,想学习Python需要多长时间
  6. 阿里巴巴叔同谈云原生和云计算
  7. 100种不错的工具和资源
  8. regsvr32.exe是什么东西
  9. java连接sftp的几种方式_Java使用SFTP和FTP两种连接服务器的方式实现对文件的上传下载...
  10. snipaste怎么滚动截长图_【神器】Snipaste——最好用的截图、贴图软件,没有之一...
  11. Word文档批量导入
  12. 大数据面试3分钟自我介绍_快手大数据岗位招聘面试题分享
  13. 疯狂动物城简介第一台通用计算机,疯狂动物城 简介
  14. 爬取斗鱼房间号信息-计算在线观看总人数
  15. 节约内存,请使用标签页管理工具:onetab、better onetab
  16. System Silencer – 离开时 让电脑自动开始任务
  17. minicom - 友好易用的串口通信程序
  18. @Value取不到值的原因
  19. 巨人java生鲜app下载_Java生鲜电商平台-生鲜电商商品中心系统设计与数据库架构(生鲜小程序/APP)...
  20. tZERO母公司Overstock股票五个月暴涨37倍背后:已深耕区块链业务数年

热门文章

  1. 软件工程——需求分析
  2. 博弈论模型——Part 1
  3. Stackelberg 博弈模型求解
  4. Dev-Cpp_6.0下载
  5. 怎么把pdf拆分成一页一页的?
  6. 孙玄:分布式系统选主怎么玩
  7. 基于c语言的拉马努金法计算圆周率近似值
  8. 圆孔夫琅禾费衍射 matlab,信息光学基于matlab圆孔圆环夫琅禾费衍射论文副本
  9. 实习商汤,校招华为,我的深度学习之路
  10. linux 好看 字体下载,字体下载大宝库:30款好看的免费英文字体