欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言實現(xiàn)2048游戲

 更新時間:2017年07月28日 15:56:59   作者:半片瓜  
這篇文章主要為大家詳細介紹了C語言實現(xiàn)2048小游戲,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)2048小游戲的具體代碼,供大家參考,具體內(nèi)容如下

具有以下特點:

1.linux下完成

2.非堵塞鍵盤讀取

3.隨機生成2和4

#include <stdio.h> 
#include <stdlib.h> 
#include <unistd.h> 
 
#define TTY_PATH "/dev/tty" 
#define STTY_ON "stty raw -echo -F" 
#define STTY_OFF "stty -raw echo -F" 
 
int map[4][4]; 
 
typedef struct node 
{ 
 int x; 
 int y; 
 int num; 
}Node; 
Node node; 
 
void init_map()//初始化全部方格 
{ 
 int i, j; 
 for(i=0; i<4; i++) 
  for(j=0; j<4; j++) 
   map[i][j] = 0; 
} 
 
void new_node()//新增方格,避免重復。 
{ 
 int x = 0, y = 0 ,num = 0; 
 do{ 
 int fals = 1; 
 int i,j; 
 for(i=0; i<4; i++) 
  for(j=0; j<4; j++) 
   if(map[i][j] == 0) 
    fals =0; 
 if(fals)//新方格無法被填入,游戲失敗 
 { 
  system("clear"); 
  printf("game over!!!!!!!!!!!\n"); 
  exit(0); 
 }  
 x = rand() % 4; 
 y = rand() % 4; 
 num = rand() % 2; 
 
 if(num == 0) 
  num = 3; 
 else if(num == 1) 
  num = 5;  
 }while(map[x][y] > 0); 
  node.x = x; 
  node.y = y; 
  node.num = num; 
  map[x][y] = node.num; 
} 
 
void show()//彩色打印數(shù)字 
{ 
 int i, j; 
 for(i=0; i<4; i++) 
 { 
  for(j=0; j<4; j++) 
  { 
   if(map[i][j]%2 == 1) 
   { 
    map[i][j] -= 1; 
    printf("\33[31m%d\33[0m\t",map[i][j]); 
   } 
   else if(map[i][j] == 0) 
   { 
    printf("%d\t",map[i][j]); 
   } 
   else if(map[i][j] == 2) 
   { 
    printf("\33[32m%d\33[0m\t",map[i][j]); 
   } 
   else if(map[i][j] == 4) 
   { 
    printf("\33[33m%d\33[0m\t",map[i][j]); 
   } 
   else if(map[i][j] == 8) 
   { 
    printf("\33[34m%d\33[0m\t",map[i][j]); 
   } 
   else if(map[i][j] == 16) 
   { 
    printf("\33[35m%d\33[0m\t",map[i][j]); 
   } 
   else if(map[i][j] == 32) 
   { 
    printf("\33[36m%d\33[0m\t",map[i][j]); 
   } 
   else 
   { 
    printf("\33[44m%d\33[0m\t",map[i][j]); 
   } 
  } 
  printf("\n"); 
 } 
} 
void left() 
{ 
 int i, j, z, tmp; 
 for(i=0; i<4; i++)//全體方格左移 
  for(j=0; j<4; j++) 
   if(map[i][j] == 0 ) 
    for(z = j + 1; z<4; z++) 
     if(map[i][z] > 0) 
     { 
      tmp = map[i][j]; 
      map[i][j] = map[i][z]; 
      map[i][z] = tmp; 
      break; 
     } 
 for(i=0; i<4; i++)//如果方格數(shù)字相同則,相加,通過主函數(shù)多次調(diào)用,排列好 
  for(j=0; j<4; j++) 
   if(map[i][j] > 0 ) 
    for(z = j + 1; z<4; z++) 
     if(map[i][z] > 0) 
      if(map[i][z] == map[i][j]) 
      { 
       map[i][j] *= 2; 
       map[i][z] = 0; 
      }else 
       break; 
     else 
      break; 
   else 
    break; 
} 
 
void right() 
{ 
 int i, j, z, tmp; 
 for(i=0; i<4; i++) 
  for(j=3; j>=0; j--) 
   if(map[i][j] == 0 ) 
    for(z = j-1; z>=0; z--) 
     if(map[i][z] > 0) 
     { 
      tmp = map[i][j]; 
      map[i][j] = map[i][z]; 
      map[i][z] = tmp; 
      break; 
     } 
 for(i=0; i<4; i++) 
  for(j=3; j>=0; j--) 
   if(map[i][j] > 0 ) 
    for(z = j-1; z>=0; z--) 
     if(map[i][z] > 0) 
      if(map[i][z] == map[i][j]) 
      { 
       map[i][j] *= 2; 
       map[i][z] = 0; 
      }else 
       break; 
     else 
      break; 
   else 
    break; 
} 
void up() 
{ 
 int i, j, z, tmp; 
 for(i=0; i<4; i++) 
  for(j=0; j<4; j++) 
   if(map[j][i] == 0 ) 
    for(z = j+1; z<4; z++) 
     if(map[z][i] > 0) 
     { 
      tmp = map[j][i]; 
      map[j][i] = map[z][i]; 
      map[z][i] = tmp; 
      break; 
     } 
 for(i=0; i<4; i++) 
  for(j=0; j<4; j++) 
   if(map[j][i] > 0 ) 
    for(z = j+1; z<4; z++) 
     if(map[z][i] > 0) 
      if(map[z][i] == map[j][i]) 
      { 
       map[j][i] *= 2; 
       map[z][i] = 0; 
      }else 
       break; 
     else 
      break; 
   else 
    break; 
} 
void down() 
{ 
 int i, j, z, tmp; 
 for(i=0; i<4; i++) 
  for(j=3; j>=0; j--) 
   if(map[j][i] == 0 ) 
    for(z = j-1; z>=0; z--) 
     if(map[z][i] > 0) 
     { 
      tmp = map[j][i]; 
      map[j][i] = map[z][i]; 
      map[z][i] = tmp; 
      break; 
     } 
 for(i=0; i<4; i++) 
  for(j=3; j>=0; j--) 
   if(map[j][i] > 0 ) 
    for(z = j-1; z>=0; z--) 
     if(map[z][i] > 0) 
      if(map[z][i] == map[j][i]) 
      { 
       map[j][i] *= 2; 
       map[z][i] = 0; 
      }else 
       break; 
     else 
      break; 
   else 
    break; 
} 
void move(char ch) 
{ 
 switch(ch) 
 { 
  case 'a': 
   left(); 
   break; 
  case 'd': 
   right(); 
   break; 
  case 'w': 
   up(); 
   break; 
  case 's': 
   down(); 
   break; 
 } 
} 
 
char in_direct()//非堵塞輸入 
{ 
 fd_set fd; 
 struct timeval tv; 
 char ch; 
 FD_ZERO(&fd); 
 FD_SET(0, &fd); 
 tv.tv_sec = 0; 
 tv.tv_usec = 10; 
 if(select(1, &fd ,NULL, NULL, &tv) > 0) 
 {  
   ch = getchar(); 
 }  
 return ch; 
} 
int main() 
{ 
 srand(time(NULL)); 
 init_map(); 
 new_node(); 
 show(); 
 char ch; 
 int i=0; 
 while(1) 
 { 
  system(STTY_ON TTY_PATH); 
  ch = in_direct(); 
  system(STTY_OFF TTY_PATH); 
  if(ch=='a'||ch=='d'||ch=='s'||ch=='w') 
  { 
   system("clear"); 
   for(i=0;i<3;i++)//重復多次才能排序好 
    move(ch); 
   new_node(); 
   show(); 
    
  } 
  if(ch=='q')//退出游戲 
  { 
   system("clear"); 
   printf("game over!!!!!!!!\n"); 
   break; 
  } 
  usleep(500000); 
 } 
 return 0; 
} 

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++動態(tài)內(nèi)存分配(new/new[]和delete/delete[])詳解

    C++動態(tài)內(nèi)存分配(new/new[]和delete/delete[])詳解

    這篇文章主要介紹了C++動態(tài)內(nèi)存分配(new/new[]和delete/delete[])詳解的相關(guān)資料,需要的朋友可以參考下
    2017-05-05
  • C和C++中argc和argv的含義及用法詳解

    C和C++中argc和argv的含義及用法詳解

    argv 是 argument vector的縮寫,表示傳入main函數(shù)的參數(shù)序列或指針,這篇文章主要介紹了C和C++中argc和argv的含義以及用法,需要的朋友可以參考下
    2022-11-11
  • C語言基于圖形庫實現(xiàn)雙人貪吃蛇

    C語言基于圖形庫實現(xiàn)雙人貪吃蛇

    這篇文章主要為大家詳細介紹了C語言基于圖形庫實現(xiàn)雙人貪吃蛇,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • C語言各種符號的使用介紹下篇

    C語言各種符號的使用介紹下篇

    C?語言的基本符號就有?20?多個,每個符號可能同時具有多重含義,而且這些符號之間相互組合又使得?C?語言中的符號變得更加復雜起來
    2022-08-08
  • c語言單鏈表尾添加的深入講解

    c語言單鏈表尾添加的深入講解

    這篇文章主要給大家介紹了關(guān)于c語言單項鏈表尾添加的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • C/C++中的?Qt?StandardItemModel?數(shù)據(jù)模型應用解析

    C/C++中的?Qt?StandardItemModel?數(shù)據(jù)模型應用解析

    QStandardItemModel?是標準的以項數(shù)據(jù)為單位的基于M/V模型的一種標準數(shù)據(jù)管理方式,本文給大家介紹C/C++中的?Qt?StandardItemModel?數(shù)據(jù)模型應用解析,感興趣的朋友跟隨小編一起看看吧
    2021-12-12
  • C語言實現(xiàn)輸出平均成績最高學生的信息

    C語言實現(xiàn)輸出平均成績最高學生的信息

    這篇文章主要介紹利用C語言實現(xiàn)輸出平均成績最高學生的信息,文章舉例說明并附有詳細代碼,需要的朋友可以參考一下
    2021-10-10
  • C語言結(jié)構(gòu)體內(nèi)存對齊詳解

    C語言結(jié)構(gòu)體內(nèi)存對齊詳解

    大家好,本篇文章主要講的是C語言結(jié)構(gòu)體內(nèi)存對齊詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-01-01
  • 淺談C++性能榨汁機之偽共享

    淺談C++性能榨汁機之偽共享

    使給定內(nèi)存位置被一個線程所訪問,可能還是會有乒乓緩存的存在,是因為另一種叫做偽共享(false sharing)的效應。即使數(shù)據(jù)存儲在緩存行中,多個線程對數(shù)據(jù)中的成員進行訪問時,硬件緩存還是會產(chǎn)生乒乓緩存。本文將介紹C++中的偽共享
    2021-06-06
  • C++實現(xiàn)簡單校園導游系統(tǒng)

    C++實現(xiàn)簡單校園導游系統(tǒng)

    這篇文章主要為大家詳細介紹了C++實現(xiàn)簡單校園導游系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評論