C语言贪吃蛇实现 链表学习

以下代码片段就是整个源代码

代码主要是github上大佬写的,附上地址(https://github.com/mnisjk/snake.git)

我又在这基础上优化了点,释放漏释放的内存,禁止蛇反向运动

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <curses.h>
#include <sys/select.h>
#include <time.h>

#define SRC_WIDTH 70
#define SRC_HEIGHT 20

WINDOW *g_mainwin;
int g_oldcur, g_score = 0, g_width, g_height;

typedef struct
{
    int x;
    int y;
} pos;

pos fruit;

bool *spaces;


// queue stuff
struct s_node
{
    pos *position;
    struct s_node *prev;
    struct s_node *next;
} *front = NULL,*back =NULL;

typedef struct s_node node;

pos * peek(){
    return front == NULL ? NULL : front->position;
}

node * dequeue(){
    node *oldfront = front;
    front = front->next;
    return oldfront;
}

//queue a position at the back
void enqueue(pos position)
{
    pos *newpos = (pos *)malloc(sizeof(position));
    node *newnode = (node *)malloc(sizeof(node));

    newpos->x = position.x;
    newpos->y = position.y;
    newnode->next = newnode->prev = NULL;
    newnode->position = newpos;
    if(front == NULL && back ==NULL)
        front = back 
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值