使用Devc++写的一个简单版贪吃蛇程序,不过,在未配置之前,是不包含图形库的,所以需要自己配置新的环境

-------------------------------------------------------------分割线----------------------------------------------------------------

#include<stdio.h>
#include<graphics.h>
#include<conio.h>
#include<time.h>
#include<windows.h>
main()
{
 int x[200]={200,210,220},y[200]={60,60,60},i,n=3,d=3,key;
 int food_x,food_y,flag=0,score=0;
 char str[100];
 initwindow(640,480);
 setcolor(RED);
 outtextxy(50,30,"greedysnake1.0");
 outtextxy(400,30,"score:");//初始化分数显示
 itoa(score,str,10);
 outtextxy(450,30,str);
 rectangle(50,50,500,400);
 setcolor(WHITE);//画初始蛇
 for(i=0;i<n;i++)
  rectangle(x[i],y[i],x[i]+10,y[i]+10);
 while(1)
 {
  if(flag==0)//发食物
  {
   srand((unsigned)time(NULL));
   food_x=rand()%400+50;
   food_y=rand()%300+50;
   while(food_x%10!=0) food_x++;
   while(food_y%10!=0) food_y++;
   flag=1;
   rectangle(food_x,food_y,food_x+10,food_y+10);
  }
  if(food_x==x[0]&&food_y==y[0])//吃食物
  {
   setcolor(BLACK);
   rectangle(food_x,food_y,food_x+10,food_y+10);
   n++;
   flag=0;
   score+=100;
   itoa(score,str,10);//整数分数转换为字符串
   setcolor(WHITE);//显示分数
   outtextxy(450,30,str);
  }
  Sleep(200);//擦蛇
  setcolor(BLACK);
  for(i=0;i<n;i++)
   rectangle(x[i],y[i],x[i]+10,y[i]+10);
  for(i=n-1;i>=1;i--)//移动
  {
   x[i]=x[i-1];
   y[i]=y[i-1];
  }
  if(kbhit()!=0)//如果有按键发生,则执行语句体
  {
   key=getch();
   switch(key)
   {
    case'w':d=1;break;
    case's':d=2;break;
    case'a':d=3;break;
    case'd':d=4;break;
    case'p':getch();
   }
  }
  switch(d)//控制蛇头的方向
  {
   case 1:y[0]-=10;break;
   case 2:y[0]+=10;break;
   case 3:x[0]-=10;break;
   case 4:x[0]+=10;break;
  }
  setcolor(WHITE);//画蛇
  for(i=0;i<n;i++)
   rectangle(x[i],y[i],x[i]+10,y[i]+10);
  if(x[0]<=50&&x[0]>=0||x[0]<=640&&x[0]>=500||y[0]<=50&&y[0]>=0||y[0]<=480&&y[0]>=400)//撞墙死
  {
   break;
  }
 }
 closegraph();
}

Devc++贪吃蛇的更多相关文章

  1. Android快乐贪吃蛇游戏实战项目开发教程-01项目概述与目录

    一.项目简介 贪吃蛇是一个很经典的游戏,也很适合用来学习.本教程将和大家一起做一个Android版的贪吃蛇游戏. 我已经将做好的案例上传到了应用宝,无病毒.无广告,大家可以放心下载下来把玩一下.应用宝 ...

  2. 用C++实现的贪吃蛇游戏

    我是一个C++初学者,控制台实现了一个贪吃蛇游戏. 代码如下: //"贪吃蛇游戏"V1.0 //李国良于2016年12月29日编写完成 #include <iostream& ...

  3. [LeetCode] Design Snake Game 设计贪吃蛇游戏

    Design a Snake game that is played on a device with screen size = width x height. Play the game onli ...

  4. JavaScript-简单的贪吃蛇小游戏

    实现逻辑: //获取Html中的格子(行,列) //建立数组存储所有格子(x,y) //建立数组用于存储蛇身(x,y) //生成随机坐标(x,y)的函数 //随机创建蛇身并存储到蛇身数组 //创建食物 ...

  5. juery实现贪吃蛇的游戏

    今天用juery做了一个贪吃蛇的游戏,代码比较简陋,不过作为这些天学习juery的成果,非常有成就感.另外关于代码内容如有雷同不胜荣幸. 更改了下 让头和身子的颜色不一样 这样好区分些,虽然还是不怎么 ...

  6. HTML 5 背离贪吃蛇 写成了类似于屏幕校准

    中间写了改 改了写 还是没做出自己满意的效果 ,看来自己的确不是一个走前端的料子.当然h5还是学一点好一点 具体说来 就是 在canvas 的画布中 鼠标点击后画上一个圆形 然后就有随机的在画布上面出 ...

  7. 控制台游戏引擎CGE——贪吃蛇

    今天我也来发一个控制台游戏.先看图: 缘起 LZ是一个有严重拖延症的人,表现的形式就是隔一段时间就要刷一刷博客园. 这不前几天,看到了魏大师<使用Lua脚本语言开发出高扩展性的系统...> ...

  8. 原生JS制作贪吃蛇小游戏

    感情都在代码里,来,干了!... <!doctype html> <html> <head> <meta http-equiv="Content-T ...

  9. 基于AT89C51单片机的贪吃蛇电子游戏(仿真)

    有关贪吃蛇的历史发展可以看一下这个网址,贪吃蛇最初的设计和现在并不相同..http://www.techweb.com.cn/internet/2013-02-21/1278055.shtml 该项目 ...

随机推荐

  1. Apache http server和tomcat的区别

    Apache官方网站:http://www.apache.org/Tomcat官方网站:http://tomcat.apache.org/ 1. Apache是web服务器,Tomcat是应用(jav ...

  2. 数据结构之 图论---最小生成树(prim + kruskal)

    图结构练习——最小生成树 Time Limit: 1000MS Memory limit: 65536K 题目描述  有n个城市,其中有些城市之间可以修建公路,修建不同的公路费用是不同的.现在我们想知 ...

  3. dtd文件中写的引用实体被xml文件引用后无法在浏览器中显示的问题

    解决方案:把dtd文件由被xml文件外部引用改成被xml文件内部引用. 例子: 1.xml文件: <?xml version="1.0" encoding="UTF ...

  4. Android-利用LinearGradient实现文字一闪一闪

    效果如下图所示: 具体实现方式如下: 1,自定义一个LinearGradientTextView 继承 TextView ,重写onSizeChanged和onDraw.: public class ...

  5. IOC入门1

    1.配置文件 <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http:/ ...

  6. AC自动机-题目集合

    AC自动机-题目集合 模板 如果你想要学习AC自动机,推荐一些学习资料. 学习可以看这篇博客 http://blog.csdn.net/niushuai666/article/details/7002 ...

  7. hdu-5003 Osu!(水题)

    题目链接: Osu! time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 65536/65536 K (Java/Others) Prob ...

  8. 字面量(literal)与 C 语言复合字面量(compound literals)

    在计算机科学中,字面量(literal)是用于表达源代码中一个固定值的表示法(notation)(字面量是相对变量常量等定义的,无论是常量还是变量,其值在某一时刻总是确定的,只是变量可以反复赋值.刷新 ...

  9. luogu 3389 【模板】高斯消元

    大概就是对每一行先找到最大的减小误差,然后代入消元 #include<iostream> #include<cstdio> #include<cstring> #i ...

  10. selenium_page_object

    最简单的pageobject github地址:https://github.com/defnngj/selenium_page_objects