C语言 小游戏之贪吃蛇

C语言 小游戏之贪吃蛇

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

        还记得非常久曾经听群里人说做贪吃蛇什么的,那时候大一刚学了C语言,认为非常难,根本没什么思路。

前不久群里有些人又在谈论C语言贪吃蛇的事了,看着他们在做,我也打算做一个出来。

如今大三,经过了这一年半的编程,如今认为这个C语言的贪吃蛇还是比較简单的,花的时间不非常多!

我认为主要是思路正确,基本上就米什么大的问题。 

 

如今贴上我的代码和我的详解,希望大家多交流。

首先说下我这个贪吃蛇仅仅是一个简单的,游戏结束有2种可能:一碰墙,二自杀即蛇头碰到蛇身。

如有不好之处,请见谅把。

 

首先说下我这个贪吃蛇仅仅是一个简单的,游戏结束有2种可能:一碰墙,二自杀即蛇头碰到蛇身。
如有不好之处,请见谅把。
 


//*******************************************************
//**************版权所有***2011.9.20***咸鱼**************
//*******************************************************
//*友情提示:如想速度快点,请改小_sleep(500)函数中參数*****
//*******************************************************
//*****************如写的不好,请见谅*********************
//*******************************************************
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <string.h>
#include <time.h>
const int H = 8;   //地图的高
const int L = 16;  //地图的长
char GameMap[H][L];   //游戏地图
int  key;  //按键保存
int  sum = 1, over = 0;  //蛇的长度, 游戏结束(自吃或碰墙)
int  dx[4] = {0, 0, -1, 1};  //左、右、上、下的方向
int  dy[4] = {-1, 1, 0, 0};
struct Snake   //蛇的每一个节点的数据类型
{
 int x, y;  //左边位置
 int now;   //保存当前节点的方向, 0,1,2,3分别为左右上下
}Snake[H*L];
const char Shead = '@';  //蛇头
const char Sbody = '#';  //蛇身
const char Sfood = '*';  //食物
const char Snode = '.';  //'.'在地图上标示为空
void Initial();  //地图的初始化
void Create_Food(); //在地图上随机产生食物
void Show();   //刷新显示地图
void Button();  //取出按键,并推断方向
void Move();   //蛇的移动
void Check_Border();  //检查蛇头是否越界
void Check_Head(int x, int y);   //检查蛇头移动后的位置情况
int main() 
{
 Initial();
 Show();
 return 0;
}
void Initial()  //地图的初始化
{
 int i, j;
 int hx, hy;
 system("title 贪吃蛇");  //控制台的标题
 memset(GameMap, '.', sizeof(GameMap));  //初始化地图所有为空'.'
 system("cls");
 srand(time(0));   //随机种子
 hx = rand()%H;    //产生蛇头
 hy = rand()%L;
 GameMap[hx][hy] = Shead;
 Snake[0].x = hx;  Snake[0].y = hy;
 Snake[0].now = -1;
 Create_Food();   //随机产生食物
 for(i = 0; i < H; i++)   //地图显示
 { 
  for(j = 0; j < L; j++)
   printf("%c", GameMap[i][j]);
  printf("\n");
 }
  
 printf("\n小小C语言贪吃蛇\n");
 printf("按随意方向键開始游戏\n");
 
 getch();   //先接受一个按键,使蛇開始往该方向走
 Button();  //取出按键,并推断方向
}
void Create_Food()  //在地图上随机产生食物
{
 int fx, fy;
 while(1)
 {
  fx = rand()%H;
     fy = rand()%L;
  
  if(GameMap[fx][fy] == '.')  //不能出如今蛇所占有的位置
  { 
   GameMap[fx][fy] = Sfood;
      break;
  }
 }
}
void Show()  //刷新显示地图
{
 int i, j;
 while(1)
 {  
  _sleep(500); //延迟半秒(1000为1s),即每半秒刷新一次地图
  Button();   //先推断按键在移动
  Move();
  if(over)  //自吃或碰墙即游戏结束
  { 
   printf("\n**游戏结束**\n");
   printf("     >_<\n");
   getchar();
      break;
  }
  system("cls");   //清空地图再显示刷新吼的地图
  for(i = 0; i < H; i++) 
  { 
   for(j = 0; j < L; j++)
    printf("%c", GameMap[i][j]);
   printf("\n");
  }
  
  printf("\n小小C语言贪吃蛇\n");
  printf("按随意方向键開始游戏\n");
 }
}
void Button()  //取出按键,并推断方向
{
 if(kbhit() != 0) //检查当前是否有键盘输入,若有则返回一个非0值,否则返回0
 { 
  while(kbhit() != 0)  //可能存在多个按键,要所有取完,以最后一个为主
      key = getch(); //将按键从控制台中取出并保存到key中
  switch(key)
  {   //左
   case 75:  Snake[0].now = 0;
          break;
            //右
            case 77:  Snake[0].now = 1;     
          break;
            //上
   case 72:  Snake[0].now = 2;
          break;
            //下
   case 80:  Snake[0].now = 3;
          break;
  }
 }
}
void Move()   //蛇的移动
{
 int i, x, y;
    int t = sum;  //保存当前蛇的长度
 //记录当前蛇头的位置,并设置为空,蛇头先移动
 x = Snake[0].x;  y = Snake[0].y;  GameMap[x][y] = '.';
 Snake[0].x = Snake[0].x + dx[ Snake[0].now ];
 Snake[0].y = Snake[0].y + dy[ Snake[0].now ];
 Check_Border();   //蛇头是否越界
 Check_Head(x, y);  //蛇头移动后的位置情况,參数为: 蛇头的開始位置
 if(sum == t)  //未吃到食物即蛇身移动哦
    for(i = 1; i < sum; i++)  //要从蛇尾节点向前移动哦,前一个节点作为參照
 {
  if(i == 1)   //尾节点设置为空再移动
   GameMap[ Snake[i].x ][ Snake[i].y ] = '.';
  
  if(i == sum-1)  //为蛇头后面的蛇身节点,特殊处理
  {
   Snake[i].x = x;
         Snake[i].y = y;
      Snake[i].now = Snake[0].now;
  }
  else   //其它蛇身即走到前一个蛇身位置
  {
   Snake[i].x = Snake[i+1].x;
         Snake[i].y = Snake[i+1].y;
      Snake[i].now = Snake[i+1].now;
  }
   
  GameMap[ Snake[i].x ][ Snake[i].y ] = '#'; //移动后要置为'#'蛇身 
 }
}
void Check_Border()  //检查蛇头是否越界
{
 if(Snake[0].x < 0 || Snake[0].x >= H
 || Snake[0].y < 0 || Snake[0].y >= L)
     over = 1;
}
void Check_Head(int x, int y)  //检查蛇头移动后的位置情况
{
 
 if(GameMap[ Snake[0].x ][ Snake[0].y ] == '.')  //为空
  GameMap[ Snake[0].x ][ Snake[0].y ] = '@';
 else
  if(GameMap[ Snake[0].x ][ Snake[0].y ] == '*')  //为食物
  {
   GameMap[ Snake[0].x ][ Snake[0].y ] = '@';  
   Snake[sum].x = x;   //新添加�的蛇身为蛇头后面的那个
      Snake[sum].y = y;
      Snake[sum].now = Snake[0].now;
         GameMap[ Snake[sum].x ][ Snake[sum].y ] = '#'; 
   sum++;
   Create_Food();  //食物吃完了立即再产生一个食物
  }
  else
   over = 1;
}

C语言 小游戏之贪吃蛇
 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118958.html原文链接:https://javaforall.net

(0)
上一篇 2021年11月28日 下午8:00
下一篇 2021年11月28日 下午8:00


相关推荐

  • 微信小程序轮播图禁止滚动

    微信小程序轮播图禁止滚动wxml<swiper-itemcatchtouchmove=’catchTouchMove’></swiper-item>jscatchTouchMove(e){returnfalse},

    2022年5月21日
    45
  • ubuntu系统使用Anaconda安装tensorflow-gpu环境

    ubuntu系统使用Anaconda安装tensorflow-gpu环境

    2021年4月9日
    158
  • goland 2022 永久激活码_在线激活2022.03.13「建议收藏」

    (goland 2022 永久激活码)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年4月2日
    3.0K
  • 安卓chrome 扫描二维码_付款扫的是条形码还是二维码

    安卓chrome 扫描二维码_付款扫的是条形码还是二维码了解二维码这个东西还是从微信中,当时微信推出二维码扫描功能,自己感觉挺新颖的,从一张图片中扫一下竟然能直接加好友,不可思议啊,那时候还不了解二维码,呵呵,然后做项目的时候,老板说要加上二维码扫描功能,然后自己的屁颠屁颠的去百度,google啥的,发现很多朋友都有介绍二维码扫描的功能,然后我就跟着人家的介绍自己搞起了二维码扫描功能,跟着人家的帖子,很快我的项目就加入了扫描二维码的功能,然后自己还很开

    2025年8月20日
    3
  • CDN加速服务器_suv加速排行榜

    CDN加速服务器_suv加速排行榜CDN全称Contentdeliverynetwork,中文内容分发网络,目的是通过在现有的Internet中增加一层新的网络架构,将网站的内容发布到最接近用户的网络”边缘”,从技术上全面解决由于网络带宽小、用户访问量大、网点分布不均等原因所造成的用户访问网站响应速度慢的问题。简单地讲,如果觉得自己的网站的打开速度很慢,可以用CDN来加速网站访问,如果网站的流量非常大,用CDN则可以分担主

    2025年8月11日
    6
  • mysql分页查询倒序_【Mysql笔记】MySQL实现分页查询[通俗易懂]

    limit基本实现方式一般情况下,客户端通过传递pageNo(页码)、pageSize(每页条数)两个参数去分页查询数据库中的数据,在数据量较小(元组百/千级)时使用MySQL自带的limit来解决这个问题:收到客户端{pageNo:1,pagesize:10}select*fromtablelimit(pageNo-1)*pageSize,pageSize;收到客户端{pa…

    2022年4月15日
    201

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号