C语言编写的贪食蛇程序.c

//家谱的建立与查询
#include "stdio.h"
#include "stdlib.h"


typedef struct node{
char  name;
char  sex;
int   age;
int   flag;
}node;


typedef struct ft{
struct node l;
struct node m;
struct ft *lchild;
struct ft *rchild;
}ft;


ft *search(ft *p,char ch)//输入头指针,姓名
{
ft *q;


if(p==NULL) return NULL;//没有家谱,头指针下为空


if(p->l.name==ch) return p;//家谱不为空,头指针下有这个人
if(p->m.name==ch) return p;//家谱不为空,头指针下有这个人
if(p->lchild)
{
q=search(p->lchild,ch);//在做孩子中找
if(q) return q;//找到
}
if(p->rchild)
{
q=search(p->rchild,ch);//在右孩子中找
if(q!=NULL) return q;
}


    return NULL;//没有找到
}
void done(ft *p,char b,char c,int a)//建立家谱孩子结点
{  
p->l.name=b;
    p->l.sex=c;
    p->l.age=a;
    p->l.flag=1;//标志设置
}
void done1(ft *p,char b,char c,int a)//建立家谱配偶节点
{  
p->m.name=b;
    p->m.sex=c;
    p->m.age=a;
    p->m.flag=1;
}




void main()
{
ft  *root,*n,*h,*t=NULL;
int i,j=1,a,flag=0;
    char b,c,d;
    
   
printf("***\t***\t***\t家     谱\t***\t***\t***\n");
printf("建立家谱的头指针:\n");

    
    root=(ft *)malloc(sizeof(ft));
printf("输入姓名(char),性别(char),年龄(int):\n");
    scanf("%c %c %d",&b,&c,&a);//输入姓名,性别,年龄
    
root->rchild=NULL;
root->lchild=NULL;
   
     done(root,b,c,a);//存入结构




 while(j!=0)
{
printf("选择操作(输入1或2):\n\t0.退出\n\t1.输入\n\t2.查找\n ");
scanf("%d",&j);

if(j==1)
  {
getchar();
printf("请输入相关人姓名:\n");//判断是否有重名
scanf("%c",&d);
n=search(root,d);
while(n==NULL)
{

printf("此人不存在,请输入姓名:\n");
getchar();
scanf("%c",&d);
n=search(root,d);
}

     
printf("\t选择家庭成员类别:\n\t1.配偶\n\t2.孩子\n");
 scanf("%d",&i);
if(i==1)
{     
getchar();
printf("配偶输入:\n");
    scanf("%c %c %d",&b,&c,&a);
//h=(ft *)malloc(sizeof(ft));
    done1(n,b,c,a);
    printf("完成!\n");
}

else//i=2孩子 
{
 getchar();
 if(n->rchild==NULL)
 { 
 
  n->rchild=(ft *)malloc(sizeof(ft));
        
        n->rchild->lchild=NULL;
        n->rchild->rchild=NULL;
printf("孩子输入:\n");
        scanf("%c %c %d",&b,&c,&a);
        done(n->rchild,b,c,a);
         printf("完成!\n");
      }
  else{
      
      n=n->rchild;
          while(n->lchild!=NULL)
            n=n->lchild;
      t=(ft *)malloc(sizeof(ft));
      printf("孩子输入:\n");
      scanf("%c %c %d",&b,&c,&a);
      done(t,b,c,a);
      t->lchild=NULL;
          t->rchild=NULL;
      n->lchild=t;
          
       
      printf("完成!\n");
       }
 
}

}
if(j==2)
  {
  getchar();
printf("输入姓名,查找相关信息:\n");
scanf("%c",&d);
n=search(root,d);
while(n==NULL)
{

printf("此人不存在,请再次输入:\n");
getchar();
scanf("%c",&d);
n=search(root,d);
}


printf("此人:\n");//?
printf("%c %c %d\n",n->l.name,n->l.sex,n->l.age);
printf("此人的配偶为:\n");//?


if(n->m.flag==1)
printf("%c %c %d\n",n->m.name,n->m.sex,n->m.age);
else printf("此人未婚!\n");
printf("此人的孩子:\n");
if(n->rchild==NULL)
printf("此人没有孩子!\n");
else if(n->rchild->lchild==NULL)
printf("%c %c %d\n",n->rchild->l.name,n->rchild->l.sex,n->rchild->l.age);
else{
printf("%c %c %d\n",n->rchild->l.name,n->rchild->l.sex,n->rchild->l.age);
t=n->rchild->lchild;
while(t!=NULL)
{

printf("%c %c %d\n",t->l.name,t->l.sex,t->l.age);
t=t->lchild;

}
}

  }
}


 printf("完成!");
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
利用c编程实现简单的贪吃蛇游戏 #include <stdio.h> #include <graphics.h> #include <stdlib.h> #include <dos.h> /* * 本游戏中的食物由一个小方格表示 * 本游戏中的蛇由多个小方格组成(最少两个) * 在游戏的进行过程中,蛇每吃一格食物,则长度将增加一节(即一个小方格) */ /* * 该宏定义蛇的最大节数 */ #define SNAKE_MAX_LEN 300 /* * 定义游戏画面在屏幕中的位置 */ #define F_LEFT 50 #define F_TOP 40 #define F_RIGHT 609 #define F_BOTTOM 459 /* * 墙壁的厚度 */ #define QB_WIDTH 10 /* * 表示食物、蛇的小方格的大小 */ #define XFG_WIDTH 10 /* * 蛇的活动区域内横向、纵向可摆放小方格的个数 */ #define NUM_H ( (F_RIGHT-F_LEFT+1-2*QB_WIDTH)/XFG_WIDTH ) #define NUM_V ( (F_BOTTOM-F_TOP+1-2*QB_WIDTH)/XFG_WIDTH ) /* * 注: 在设计上面宏的时候,必须满足: * (1) 在屏幕分别率允许的范围内 * (2) (F_RIGHT-F_LEFT+1-2*QB_WIDTH)/XFG_WIDTH 必须能整除 * (3) (F_BOTTOM-F_TOP+1-2*QB_WIDTH)/XFG_WIDTH 必须能整除 */ /* * 将在蛇的活动区内以小方格为单位的坐标转换成屏幕的像素坐标 */ #define X_to_x(x) ( (x) * XFG_WIDTH + (F_LEFT+QB_WIDTH) ) #define Y_to_y(y) ( (y) * XFG_WIDTH + (F_TOP+QB_WIDTH) ) /* * 分别定义 蛇、食物、墙壁的颜色 */ #define SNAKE_COLOR RED #define FOOD_COLOR GREEN #define QB_COLOR LIGHTCYAN /* * 定义按键扫描码 */ #define K_LEFT 0x4b00 #define K_RIGHT 0x4d00 #define K_DOWN 0x5000 #define K_UP 0x4800 #define K_ESC 0x011b /* * 定义蛇移动的方向 */ #define MOVE_RIGHT 1 #define MOVE_LEFT 2 #define MOVE_UP 3 #define MOVE_DOWN 4 int score=0; /* 得分 */ int gamespeed=50000; /* 游戏速度 */ /* * 食物的属性 */ struct { int x; /* 表示食物小方格左上角的横坐标 */ int y; /* 表示食物小方格左上角的纵坐标 */ int yes; /* 是否要出现食物 */ /* 1 表示需要出现新食物, 0 表示已经存在食物 */ }food; /* * 蛇的属性 */ struct { /* * 每个小方格左上角的横坐标(x)、纵坐标(y) */ int x[SNAKE_MAX_LEN]; int y[SNAKE_MAX_LEN]; int node; /* 蛇的节数 */ int direction; /* 蛇移动方向 */ }snake; /*图形驱动*/ void MyInitGraph(void) { int GraphDriver; /* 图形设备驱动程序 */ int GraphMode; /* 图形设备模式 */ GraphDriver = DETECT; /* 请求自动检测 */ initgraph( &GraphDriver, &GraphMode, "" ); cleardevice(); } /*图形结束*/ void MyCloseGraph(void) { closegraph(); } /* 输出字符串*/ void PrintString(const char *str) { setfillstyle(SOLID_FILL,YELLOW); bar(F_LEFT,F_TOP-20,F_RIGHT,F_TOP-20+15); setcolor(BROWN); settextstyle(DEFAULT_FONT,0,1); outtextxy(F_LEFT+5,F_TOP-20+5,str); } /* * 游戏画面,左上角坐标为(F_LEFT,F_TOP),右下角坐标为(F_RIGHT,F_BOTTOM)的围墙 */ void DrawForm(void) { int i; char str[100]; setcolor(QB_COLOR); setlinestyle(SOLID_LINE,0,NORM_WIDTH); /* 设置线型 */ for(i=F_LEFT;i<=F_RIGHT-QB_WIDTH+1;i+=QB_WIDTH){ /* * 在屏幕的上边和下边分别画 56 个紧挨着的小矩形 * 小矩形的高宽都分别为10 个像素 */ rectangle(i, F_TOP, i+QB_WIDTH-1, F_TOP+QB_WIDTH-1); rectangle(i,F_BOTTOM-QB_WIDTH+1, i+QB_WIDTH-1, F_BOTTOM); } for(i=F_TOP;i<=F_BOTTOM-QB_WIDTH+1;i+=QB_WIDTH){ /* * 在屏幕的左边和右边分别画 42 个紧挨着的小矩形 * 小矩形的高宽都分别为10 个像素 */ rectangle( F_LEFT,i, F_LEFT+QB_WIDTH-1, i+QB_WIDTH-1); rectangle(F_RIGHT-QB_WIDTH+1,i, F_RIGHT, i+QB_WIDTH-1); } PrintString("Please Press A Key to play the game!"); while( kbhit() ){ /* * NULL */ } bioskey(0); } /* * 根据按键内容,改变蛇的运动方向 */ void change_direction_by_key(int key) { if( key==K_UP){ if( snake.direction!=MOVE_DOWN ){ snake.direction = MOVE_UP; } }else if( key==K_RIGHT ){ if( snake.direction!=MOVE_LEFT ){ snake.direction = MOVE_RIGHT; } }else if( key==K_LEFT ){ if( snake.direction!=MOVE_RIGHT ){ snake.direction = MOVE_LEFT; } }else if( key==K_DOWN ){ if( snake.direction!=MOVE_UP ){ snake.direction = MOVE_DOWN; } } } /*输出成绩*/ void PrintScore(/*int score*/) { char str[20]; sprintf(str,"score:%d",score); PrintString(str); } /*游戏结束*/ void GameOver(void) { cleardevice(); PrintScore(); setcolor(RED); settextstyle(0,0,4); outtextxy(200,200,"GAME OVER"); getch(); } /* * 生成一个新的食物 * 在围墙内随机生成新食物的坐标 */ void Make_A_Food() { food.x = X_to_x( rand() % NUM_H ); food.y = Y_to_y( rand() % NUM_V ); } /* * 在画面上显示食物 */ void DispFood(void) { setcolor(FOOD_COLOR); rectangle(food.x,food.y,food.x+XFG_WIDTH-1,food.y+XFG_WIDTH-1); } /* * 蛇的每个小方格往前移动一格 */ void move_snake(void) { int i; /* * 在画面上抹去蛇的最后一节 */ setcolor(BLACK); rectangle(snake.x[snake.node-1],snake.y[snake.node-1],snake.x[snake.node-1]+XFG_WIDTH-1,snake.y[snake.node-1]+XFG_WIDTH-1); /* * 根据蛇的移动方向计算蛇的每个小方格的坐标 */ for(i=snake.node-1;i>0;i--){ snake.x[i]=snake.x[i-1]; snake.y[i]=snake.y[i-1]; } switch( snake.direction ){ case MOVE_RIGHT: snake.x[0] += XFG_WIDTH; break; case MOVE_LEFT: snake.x[0] -= XFG_WIDTH; break; case MOVE_UP: snake.y[0] -= XFG_WIDTH; break; case MOVE_DOWN: snake.y[0] += XFG_WIDTH; break; } /* * 在画面上按移动后的坐标画出蛇的第一节 */ setcolor(SNAKE_COLOR); rectangle(snake.x[0],snake.y[0],snake.x[0]+XFG_WIDTH-1,snake.y[0]+XFG_WIDTH-1); /* for(i=0;i<snake.node;i++) rectangle(snake.x[i],snake.y[i],snake.x[i]+XFG_WIDTH-1,snake.y[i]+XFG_WIDTH-1); */ } /* * 将蛇的身体长一节 * 且新的一节先放在原最后一节的位置,下次循环就正常了 */
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值