70行C語言代碼實現(xiàn)貪吃蛇
本文實例為大家分享了C語言實現(xiàn)貪吃蛇的具體代碼,供大家參考,具體內(nèi)容如下
#include <stdio.h>
#include <Windows.h>
#include <conio.h>
#include <time.h>
#define MAX_WIDE 50
#define MAX_HIGH 16
short dx = 1, dy = 0, randxy, score = 0;
COORD coord;
struct Snake{
short len;
short body[MAX_WIDE*MAX_HIGH];
}snake;
void draw()
{
for(short i = 0; i < snake.len; i++){
coord.X = snake.body[i] & 127;
coord.Y = snake.body[i] >> 8;
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE), coord);
putchar('*');
}
coord.X = randxy & 127;
coord.Y = randxy >> 8;
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE), coord);
putchar('*');
}
void run()
{
char key;
short i, j;
while( snake.body[0] > 0 && ( (snake.body[0] & 127) < MAX_WIDE) && (snake.body[0]>>8 < MAX_HIGH) ){
draw();
for(;kbhit();) key = getch();
switch(key){
case 'W': dx = 0, dy = -1; break;
case 'S': dx = 0, dy = 1; break;
case 'A': dx = -1, dy = 0; break;
case 'D': dx = 1, dy = 0; break;
}
for(j = 1; j < snake.len; j++)
if(snake.body[j] == snake.body[0])
return;
if(randxy == snake.body[0]){
snake.len++, score += 10;
randxy = ((rand() % 16 + 0) <<8) | (rand() % 50 + 0);
}
for(i = snake.len-1; i > 0; i--)
snake.body[i] = snake.body[i-1];
snake.body[0] = ((snake.body[0] & 127) + dx) | ((snake.body[0] >>8) + dy)<<8;
Sleep(500);
system("cls");
}
}
int main()
{
snake.body[MAX_WIDE*MAX_HIGH] = 0;
snake.body[0] = (MAX_HIGH/2)<<8 | MAX_WIDE/2;
snake.len = 1;
srand((unsigned)time(NULL));
randxy = ((rand() % 16 + 0) <<8) | (rand() % 50 + 0);
SMALL_RECT rect;
rect.Top = 0, rect.Left = 0;
rect.Bottom = MAX_HIGH, rect.Right = MAX_WIDE;
SetConsoleWindowInfo(GetStdHandle(STD_OUTPUT_HANDLE), true, &rect);
run();
printf("Your Score:%d", score);
return 0;
}

環(huán)境:VC++6.0
該代碼效率不高,代碼又難讀,僅供娛樂。
講一下大概的實現(xiàn)思想吧:
.:其中用一個MAX_WIDE * MAX_HIGH大的數(shù)組來虛擬化snake的軀干,數(shù)組中的項保存該snake的坐標值,并且該值用一個short(16byte)類型的值表示,高8byte表示它的Y坐 標,低8byte表示它的X坐標,然后就可以遍歷該數(shù)組畫出各個坐標點。
.:至于它的移動就是通過數(shù)組的前一個項的值復(fù)制給后一個項,以此達到它的移動。
當(dāng)然也可以用鏈表代替數(shù)組實現(xiàn)該snake軀干,而且不會像數(shù)組一樣浪費內(nèi)存,但是用鏈表的話,就增加了代碼行^_^
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++實現(xiàn)LeetCode(169.求大多數(shù))
這篇文章主要介紹了C++實現(xiàn)LeetCode(169.求大多數(shù)),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-08-08
C++虛函數(shù)表與類的內(nèi)存分布深入分析理解
對C++ 了解的人都應(yīng)該知道虛函數(shù)(Virtual Function)是通過一張?zhí)摵瘮?shù)表(Virtual Table)來實現(xiàn)的。簡稱為V-Table。本文就將詳細講講虛函數(shù)表的原理與使用,需要的可以參考一下2022-08-08

