使用C语言实现2048游戏的案例-创新互联

小编给大家分享一下使用C语言实现2048游戏的案例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

为平凉等地区用户提供了全套网页设计制作服务,及平凉网站建设行业解决方案。主营业务为成都网站设计、成都网站制作、平凉网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

具有以下特点:

1.linux下完成

2.非堵塞键盘读取

3.随机生成2和4

#include  
#include  
#include  
 
#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; 
}

以上是“使用C语言实现2048游戏的案例”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联网站建设公司行业资讯频道!

另外有需要云服务器可以了解下创新互联建站www.cdcxhl.com,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


文章名称:使用C语言实现2048游戏的案例-创新互联
标题网址:http://scyanting.com/article/copdcj.html