| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1429 人关注过本帖
标题:大一党c语言初学。。关于贪吃蛇问题
只看楼主 加入收藏
XenonDDsh
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2013-12-1
收藏
 问题点数:0 回复次数:14 
大一党c语言初学。。关于贪吃蛇问题
用的编译器是vs2012。。。。有两个问题想请教各位大大。。。。
第一、蛇吃了第一个食物,第二个食物就开始随机出现乱跑,根本吃不到第二个食物。
第二、围墙画出来在蛇的运动范围内同时会出现竖型条纹
程序代码:
#define N 200
typedef struct snake S;
typedef struct food F;

 struct snake

 {
     int x[N];
     int y[N];
     int node;
     int life;
     int direction;
     int speed;

 };

 struct food
{
int x,y;
int flag;//是否改变食物的位置
};
S initsnake();//初始化蛇
F outfood();//初始化食物
void printfwall();//画墙
void drawsnake(S s);//画蛇
void drawfood(F f);//画食物
S updatesnake(S s);//修改蛇数据
S updatsnakedirection(S s);//修改蛇运动方向
F updadtfood(F f);//修改食物数据
int towall(S s);//判断蛇撞墙没
int toitself(S s);//判断蛇撞自己没
int eatfood(S s,F f);//判断吃食物
void score(int score);//设置分数
void gameover();//游戏结束
void gameplay();//游戏数据
#include<graphics.h>

void drawfood(F f)
{
    setcolor(RED);
    rectangle(f.x,f.y,f.x+10,f.y-10);
}
void printfwall()
{
    int i;
    setcolor(YELLOW);
    for(i=50;i<=600;i+=10)
    {
        rectangle(i,40,i+10,49);
        rectangle(i,45,i+10,460);
    }
    for(i=40;i<=450;i+=10)
    {
        rectangle(50,i,59,i+10);
        rectangle(601,i,610,i+10);
    }
}
void drawsnake(S s)
{
    int i;
    setcolor(BLUE);
    for(i=0;i<s.node;i++)
    {
        rectangle(s.x[i],s.y[i],s.x[i]+10,s.y[i]-10);
    }
}
int towall(S s)
{
    if(s.x[0]<55||s.x[0]>595||s.y[0]<55||s.y[0]>455)
        return 1;
    else
        return 0;
}
int toitself(S s)
{
    int i;
    for(i=3;i<s.node;i++)
    {
        if(s.x[i]==s.x[0]&&s.y[i]==s.y[0])
        {
            return 1;
        }
    }
    return 0;
}
int eatfood(S s,F f)
{
    if(s.x[0]==f.x&&s.y[0]==f.y)
    {
        return 1;
    }
    return 0;
}
S initsnake()
{
    S s;
    s.life=0;
    s.direction=1;
    s.x[0]=110;
    s.y[0]=70;
    s.x[1]=100;
    s.y[1]=70;
    s.node=1;
    return s;
}
F outfood()
{
    randomize();
    F f;
    f.x=random(520)+60;
    f.y=random(380)+60;
    while(f.x%10!=0)
    {
        f.x++;
    }
    while(f.y%10!=0)
    {
        f.y++;
    }
    f.flag=0;
    return f;
}
F updadtfood(F f)
{
    randomize();
    if(f.flag==1)
    {
        f.x=random(520)+60;
            f.y=random(380)+60;
            while (f.x%10!=0)
            {
                f.x++;
            }
            while(f.y%10!=0)
            {
                f.y++;
            }
    }
    return f;
}
S updatesnake(S s)
{
    int i;
    for(i=s.node-1;i>0;i--)
    {
        s.x[i]=s.x[i-1];
        s.y[i]=s.y[i-1];
    }
    switch (s.direction)
    {
    case 1:s.x[0]+=10;break;
    case 2:s.x[0]-=10;break;
    case 3:s.y[0]-=10;break;
    case 4:s.y[0]+=10;break;
    }
    return s;
}
S updatsnakedirection(S s)
{
    key_msg k=getkey();
    if(k.key==key_up&&s.direction!=4)
        s.direction=3;
    else
        if(k.key==key_right&&s.direction!=2)
            s.direction=1;
        else
            if(k.key==key_left&&s.direction!=1)
                s.direction=2;
            else
            if(k.key==key_down&&s.direction!=3)
                s.direction=4;
    return s;
}
void score(int score)
{
    setcolor(GREEN);
    setfont(30,0,"宋体");
    xyprintf(0,0,"分数","%d",score);
}
void gameplay()
{
    S s;
    F f;
    int score=0;
    s=initsnake();
    f=outfood();
    while (1)

    {
        for (;!kbhit();delay(300))
        {
            s=updatesnake(s);
            f=updadtfood(f);
            if (eatfood(s,f)==1)
            {
                s.node++;
                f.flag=1;
                score+=100;
            }
            if(towall(s)||toitself(s))
            {
                s.life=1;
            
                exit(0);
            }
            cleardevice();
            
                printfwall();
                printfwall();
                drawsnake(s);
                drawfood(f);
        }
        s=updatsnakedirection(s);
    }
}
void main()
{
    initgraph(640,480);
    setbkcolor(WHITE);
    gameplay();
    getch();
    closegraph();
}
搜索更多相关主题的帖子: 贪吃蛇 编译器 c语言 条纹 
2013-12-13 08:38
XenonDDsh
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2013-12-1
收藏
得分:0 
自顶。。。。。
2013-12-13 08:40
embed_xuel
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:58
帖 子:3845
专家分:11385
注 册:2011-9-13
收藏
得分:0 
这么长的代码,自己debug吧

总有那身价贱的人给作业贴回复完整的代码
2013-12-13 08:47
XenonDDsh
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2013-12-1
收藏
得分:0 
回复 3楼 embed_xuel
表示不会
2013-12-13 09:01
XenonDDsh
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2013-12-1
收藏
得分:0 
2013-12-13 15:40
flamebaby
Rank: 1
等 级:新手上路
帖 子:7
专家分:3
注 册:2013-12-8
收藏
得分:0 
没有vc 加油
2013-12-13 15:53
红魔无双
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2013-12-13
收藏
得分:0 
画围墙的里的第一个循环 的 第二行 不该是45 是450 少写了个0
2013-12-13 16:22
xiaozi2013
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:四川成都
等 级:蒙面侠
威 望:6
帖 子:830
专家分:4331
注 册:2013-12-13
收藏
得分:0 
表示作为大一党的我,,现在还在学习基本内置函数,,无力啊---------------

--整天敲那些破代码能找着媳妇儿吗。。。---
2013-12-13 17:11
XenonDDsh
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2013-12-1
收藏
得分:0 
回复 7楼 红魔无双
谢谢啊!!!围墙对了。。。那那个食物乱跑怎么办啊
2013-12-14 12:49
XenonDDsh
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2013-12-1
收藏
得分:0 
回复 8楼 xiaozi2013
我也是四川成都的0.0.。。。你哪个学校啊
2013-12-14 12:49
快速回复:大一党c语言初学。。关于贪吃蛇问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.076207 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved