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语言 小游戏之贪吃蛇
 

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • MySQL数据库:SQL优化与索引优化

    MySQL数据库:SQL优化与索引优化

  • Repeater嵌套Repeater

    Repeater嵌套Repeater
    前台页面部分:

     
        

     
       
       

  • LeetCode解题汇总目录

    此篇为学习完《数据结构与算法之美》后,在LeetCode刷题的汇总目录,方便大家查找(Ctrl+Find),一起刷题,一起PK交流!另有解题:《剑指Offer》、《程序员面试金典》、LintCode代码能力测试CAT。如果本文对你有帮助,可以给我点赞加油!通过2021,简单618/636,中等1120/1266,困难283/488

  • hikaripool信息_HikariPool源码(四)资源状态[通俗易懂]

    hikaripool信息_HikariPool源码(四)资源状态[通俗易懂]Java极客|作者/铿然一叶这是Java极客的第55篇原创文章1.本章目的了解池资源的状态,以及状态如何变迁,用于池化资源设计参考。2.HikariPool资源核心类回顾HikariPool资源相关的类如下:类说明:类职责HikariPool资源池,客户端资源操作的入口。ConcurrentBag通用的并发包工具。CopyOnWriteArrayList一个列表,用于存储资源,…

  • C++虚函数详解

    C++虚函数详解C++虚函数详解前言C++的特性使得我们可以使用函数继承的方法快速实现开发,而为了满足多态与泛型编程这一性质,C++允许用户使用虚函数**(virtualfunction)来完成运行时决议这一操作,这与一般的编译时决定**有着本质的区别。虚函数表实现原理虚函数的实现是由两个部分组成的,虚函数指针与虚函数表。虚函数指针虚函数指针**(virtualfunctionpointer)*…

  • 久违的黑客手册[通俗易懂]

    久违的黑客手册[通俗易懂]今天终于看到那件书店上摆上了《黑客手册》高兴的不得了抓起一本就跑去付帐排队的时候拿起封面看了看 晕3月份的了 55  。。。1,2月的没的买了 真不爽偏偏老板就不进1,2月的偏偏这里就这一间店有这书卖当我把钱递给老板的时候老板突然问我一句话让我苦笑不得他说看你每次都买这书你是黑客还是红客啊?……我只好开玩笑的说我红黑同杀^_^….

发表回复

您的电子邮箱地址不会被公开。

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