国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

C語言實現2048游戲

2020-01-26 13:59:37
字體:
來源:轉載
供稿:網友

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

具有以下特點:

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()//彩色打印數字 {  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++)//如果方格數字相同則,相加,通過主函數多次調用,排列好   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; } 

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 博罗县| 宜州市| 诸暨市| 蒙城县| 沈阳市| 丹东市| 玉树县| 泰州市| 沁水县| 中卫市| 沧源| 淳安县| 怀远县| 广丰县| 大关县| 白银市| 虞城县| 霍邱县| 彩票| 淳安县| 镇坪县| 忻城县| 视频| 南岸区| 松江区| 南漳县| 图片| 乡宁县| 鄂尔多斯市| 富源县| 广宗县| 泰宁县| 象州县| 太白县| 康马县| 东台市| 新竹市| 长丰县| 盐津县| 镇江市| 昭通市|