91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言代碼怎么實現貪吃蛇

發布時間:2021-06-18 14:07:59 來源:億速云 閱讀:146 作者:小新 欄目:編程語言

這篇文章主要介紹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; 
}

C語言代碼怎么實現貪吃蛇

環境:VC++6.0 

該代碼效率不高,代碼又難讀,僅供娛樂。

講一下大概的實現思想吧:

.:其中用一個MAX_WIDE * MAX_HIGH大的數組來虛擬化snake的軀干,數組中的項保存該snake的坐標值,并且該值用一個short(16byte)類型的值表示,高8byte表示它的Y坐   標,低8byte表示它的X坐標,然后就可以遍歷該數組畫出各個坐標點。

.:至于它的移動就是通過數組的前一個項的值復制給后一個項,以此達到它的移動。

當然也可以用鏈表代替數組實現該snake軀干,而且不會像數組一樣浪費內存,但是用鏈表的話,就增加了代碼行^_^

以上是“C語言代碼怎么實現貪吃蛇”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

安丘市| 田林县| 通道| 安陆市| 罗平县| 桂林市| 双流县| 睢宁县| 定兴县| 巫溪县| 依安县| 东辽县| 石渠县| 闻喜县| 丹阳市| 修文县| 高唐县| 涡阳县| 滁州市| 南华县| 乌兰察布市| 株洲市| 廊坊市| 龙井市| 庆云县| 鄢陵县| 休宁县| 大田县| 莲花县| 密云县| 若尔盖县| 华容县| 怀远县| 建宁县| 巴林右旗| 灵武市| 祁东县| 达孜县| 大石桥市| 冕宁县| 隆尧县|