您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
这篇文章主要介绍C语言代码怎么实现贪吃蛇,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
具体内容如下
#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; }
环境:VC++6.0
该代码效率不高,代码又难读,仅供娱乐。
讲一下大概的实现思想吧:
.:其中用一个MAX_WIDE * MAX_HIGH大的数组来虚拟化snake的躯干,数组中的项保存该snake的坐标值,并且该值用一个short(16byte)类型的值表示,高8byte表示它的Y坐 标,低8byte表示它的X坐标,然后就可以遍历该数组画出各个坐标点。
.:至于它的移动就是通过数组的前一个项的值复制给后一个项,以此达到它的移动。
当然也可以用链表代替数组实现该snake躯干,而且不会像数组一样浪费内存,但是用链表的话,就增加了代码行^_^
以上是“C语言代码怎么实现贪吃蛇”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。