中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档 | 网通镜像
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > 综合其它
c语言小游戏(贪食蛇)
作者:未知 时间:2005-07-27 23:18 出处:CSDN 责编:chinaitpower
              摘要:c语言小游戏(贪食蛇)

#include <stdlib.h>
#include <math.h>
#include <stdio.h>
#include <graphics.h>
int SCR[10][15];
typedef struct QNode
{int a,b;
 struct QNode *next;
}QNode,*QueuePtr;

typedef struct
{QueuePtr front;
 QueuePtr rear;
}LinkQueue;

LinkQueue *Q;
QNode *p;

void InitQueue()
{Q->front=Q->rear=(QueuePtr)malloc(sizeof(QNode));
 if(!Q->front) exit(0);
 Q->front->next=NULL;
}

void EnQueue(int x,int y)
{p=(QueuePtr)malloc(sizeof(QNode));
 if(!p) exit(0);
 p->a=x;
 p->b=y;
 p->next=NULL;
 Q->rear->next=p;
 Q->rear=p;
}

int DeQueue()
{int e;
 while(Q->front!=Q->rear)
 {p=Q->front->next;
  e=p->a;
  Q->front->next=p->next;
  if(Q->rear==p) Q->rear=Q->front;
  free(p);
  return e;
 }
 if(Q->front==Q->rear) printf("The Queue is empty!\n");
}

main()
{int score=0,i,j,RADx,RADy,key,x=100,y=100,X=100,Y=100,gd=DETECT,gm;
 randomize();
 InitQueue();
 initgraph(&gd,&gm,"");
 for(i=0;i<10;i++)
 for(j=0;j<15;j++)
 SCR[i][j]=0;
 rectangle(X-1,Y-1,X+301,Y+201);
 setfillstyle(1,GREEN);
 bar(x,y,x+18,y+18);
 EnQueue(x,y);
 SCR[0][0]=1;
 settextstyle(0,0,2);
 outtextxy(10,10,"WELCOME TO PLAY!");
 outtextxy(10,400,"exit->Esc");
 outtextxy(450,100,"SCORE:");
 do{RADx=random(200)+100;
    RADy=random(100)+100;
   }while((RADx%20)!=0||(RADy%20)!=0);
 bar(RADx,RADy,RADx+18,RADy+18);
 for(;;)
   {key=getch();
    setfillstyle(1,BLACK);
    bar(x,y,x+18,y+18);
    while(key==77&&Q->rear->a<X+280)
    {x=Q->rear->a;
     y=Q->rear->b;
     x+=20;
     setfillstyle(1,GREEN);
     bar(x,y,x+18,y+18);
     EnQueue(x,y);
     if(x!=RADx||y!=RADy)
    {x=Q->front->next->a;
     y=Q->front->next->b;
     setfillstyle(1,BLACK);
     bar(x,y,x+18,y+18);
     DeQueue();
     }
     else
     {do{RADx=random(200)+100;
 RADy=random(100)+100;
       }while((RADx%20)!=0||(RADy%20)!=0||SCR[(RADx-100)/20][(RADy-100)/20]==1);
      bar(RADx,RADy,RADx+18,RADy+18);
      SCR[(RADx-100)/20][(RADy-100)/20]=1;
      score+=100;
     }
     delay(1000000000);
     if(kbhit())
     {key=getch();
      if(key==80||key==72) break;
     }
    }
    while(key==80&&Q->rear->b<Y+180)
    {x=Q->rear->a;
     y=Q->rear->b;
     y+=20;
     setfillstyle(1,GREEN);
     bar(x,y,x+18,y+18);
     EnQueue(x,y);
     if(x!=RADx||y!=RADy)
    {x=Q->front->next->a;
     y=Q->front->next->b;
     setfillstyle(1,BLACK);
     bar(x,y,x+18,y+18);
     DeQueue();
     }
     else
     {do{RADx=random(200)+100;
 RADy=random(100)+100;
       }while((RADx%20)!=0||(RADy%20)!=0||SCR[(RADx-100)/20][(RADy-100)/20]==1);
      bar(RADx,RADy,RADx+18,RADy+18);
      SCR[(RADx-100)/20][(RADy-100)/20]=1;
     }
     delay(1000000000);
     if(kbhit())
     {key=getch();
      if(key==77||key==75) break;
     }
    }
    while(key==75&&Q->rear->a>X)
    {x=Q->rear->a;
     y=Q->rear->b;
     x-=20;
     setfillstyle(1,GREEN);
     bar(x,y,x+18,y+18);
     EnQueue(x,y);
     if(x!=RADx||y!=RADy)
    {x=Q->front->next->a;
     y=Q->front->next->b;
     setfillstyle(1,BLACK);
     bar(x,y,x+18,y+18);
     DeQueue();
     }
     else
     {do{RADx=random(200)+100;
 RADy=random(100)+100;
       }while((RADx%20)!=0||(RADy%20)!=0||SCR[(RADx-100)/20][(RADy-100)/20]==1);
      bar(RADx,RADy,RADx+18,RADy+18);
      SCR[(RADx-100)/20][(RADy-100)/20]=1;
     }
     delay(1000000000);
     if(kbhit())
     {key=getch();
      if(key==80||key==72) break;
     }
   }
   while(key==72&&Q->rear->b>Y)
    {x=Q->rear->a;
     y=Q->rear->b;
     y-=20;
     setfillstyle(1,GREEN);
     bar(x,y,x+18,y+18);
     EnQueue(x,y);
     if(x!=RADx||y!=RADy)
    {x=Q->front->next->a;
     y=Q->front->next->b;
     setfillstyle(1,BLACK);
     bar(x,y,x+18,y+18);
     DeQueue();
     }
     else
     {do{RADx=random(200)+100;
 RADy=random(100)+100;
       }while((RADx%20)!=0||(RADy%20)!=0||SCR[(RADx-100)/20][(RADy-100)/20]==1);
      bar(RADx,RADy,RADx+18,RADy+18);
      SCR[(RADx-100)/20][(RADy-100)/20]=1;
     }
     delay(1000000000);
     if(kbhit())
     {key=getch();
      if(key==77||key==75) break;
     }
    }
    if(key==27) break;
   }
 closegraph();
}



关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有