add
This commit is contained in:
parent
8008adc2aa
commit
eba0553152
112
du7/snake.c
Normal file
112
du7/snake.c
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
#include "snake.h"
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <curses.h>
|
||||||
|
|
||||||
|
//void freeAll(struct snake* prvok);
|
||||||
|
|
||||||
|
struct snake* add_snake(struct snake* snake,int x,int y){
|
||||||
|
|
||||||
|
struct snake* head = calloc(1,sizeof(struct snake));
|
||||||
|
head->x = x;
|
||||||
|
head->y = y;
|
||||||
|
head->next = snake;
|
||||||
|
|
||||||
|
return head;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct snake* remove_snake(struct snake* snake){
|
||||||
|
if(!snake->next&&!snake)
|
||||||
|
return NULL;
|
||||||
|
|
||||||
|
struct snake* last = snake;
|
||||||
|
struct snake* secondLast = snake;
|
||||||
|
|
||||||
|
while(1){
|
||||||
|
if(!last->next){
|
||||||
|
free(last);
|
||||||
|
secondLast->next=NULL;
|
||||||
|
return snake;
|
||||||
|
}
|
||||||
|
secondLast=last;
|
||||||
|
last=last->next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void free_snake(struct snake* sn){
|
||||||
|
struct snake* this = sn;
|
||||||
|
|
||||||
|
while(this){
|
||||||
|
struct snake* next = this->next;
|
||||||
|
free(this);
|
||||||
|
this = next;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
void freeAll(struct snake* prvok){
|
||||||
|
if(!prvok)
|
||||||
|
break;
|
||||||
|
|
||||||
|
else if(prvok->next)
|
||||||
|
freeAll(prvok->next);
|
||||||
|
|
||||||
|
free(prvok);
|
||||||
|
}*/
|
||||||
|
|
||||||
|
|
||||||
|
int is_snake(struct snake* snake,int x,int y){
|
||||||
|
|
||||||
|
struct snake* this = snake;
|
||||||
|
|
||||||
|
while(this){
|
||||||
|
if(this->x==x && this->y==y)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
this = this->next;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
//Spojkový zoznam =============================> celá hra
|
||||||
|
|
||||||
|
|
||||||
|
int step_state(struct state* st){
|
||||||
|
|
||||||
|
int nx = (st->snake->x + st->sx);
|
||||||
|
int ny = (st->snake->y + st->sy);
|
||||||
|
|
||||||
|
if(is_snake(st->snake,nx, ny))
|
||||||
|
return END_SNAKE;
|
||||||
|
//
|
||||||
|
for(int i = 0;i < FOOD_COUNT; i++){
|
||||||
|
if(nx==st->foodx[i]&&ny==st->foody[i]){
|
||||||
|
st->foody[i]=-1;
|
||||||
|
st->foodx[i]=-1;
|
||||||
|
|
||||||
|
add_snake(st->snake, nx, ny);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int is_all_eaten=1;
|
||||||
|
for(int i = 0;i < FOOD_COUNT; i++){
|
||||||
|
if(st->foodx[i]>=0){
|
||||||
|
is_all_eaten = 0;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(is_all_eaten)
|
||||||
|
return END_FOOD;
|
||||||
|
//
|
||||||
|
|
||||||
|
if(nx<0||ny<0||nx>=COLS||ny>=LINES)
|
||||||
|
return END_WALL;
|
||||||
|
//
|
||||||
|
|
||||||
|
if(st->snake->x != nx && st->snake->y != ny){
|
||||||
|
remove_snake(st->snake);
|
||||||
|
add_snake(st->snake, nx, ny);
|
||||||
|
}
|
||||||
|
|
||||||
|
return END_CONTINUE;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user