简单实现C语言2048游戏

 更新时间:2018年05月05日 10:34:03   作者:jiayouliying  
这篇文章主要为大家详细介绍了简单实现C语言2048游戏,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言2048游戏的具体代码,供大家参考,具体内容如下

/*2048*/ 
#include<stdio.h>  
#include<conio.h>  
#include<stdlib.h>  
#include<time.h>   
  
  
//全局变量 
int x[4][4]={0}; 
int score=0;  
int can_move; 
  
int empty()  
{  
  int i,j; 
  int n=0; 
  for(i=0;i<4;i++)  
  { 
    for(j=0;j<4;j++) 
    {  
      if(x[i][j]==0) 
      n++;  
    }  
  } 
  return n; 
}  
 
int check() 
{ 
  int i,j; 
  int a,b; 
  if(empty() == 0) 
  { 
    a=b=0; 
    for(i=0;i<4;i++)  
    { 
      for(j=0;j<3;j++) 
      {  
        if(x[i][j]==x[i][j+1]) 
        a=1; 
      }  
    } 
    for(j=0;j<4;j++)  
    { 
      for(i=0;i<3;i++) 
      {  
        if(x[i][j]==x[i+1][j]) 
        b=1; 
      }  
    } 
    if(a==0 && b==0) 
      return 0; 
    else 
      return 1;   
  } 
  else 
    return 1;  
}  
 
int win() 
{ 
  int i,j; 
  int a=0; 
  if(check()) 
  { 
    for(i=0;i<4;i++)  
    { 
      for(j=0;j<4;j++) 
      {  
        if(x[i][j]==2048) 
        a=1;  
      }  
    } 
  } 
  return a; 
} 
 
void add()  
{  
  int i,j; 
  int n=0; 
  if(empty() > 0) 
  { 
    while(n<16) 
    { 
      i=rand()%4; 
      j=rand()%4; 
      if(x[i][j] == 0) 
      { 
        if(rand()%100 < 80) 
        { 
          x[i][j]=2; 
        } 
        else 
        { 
          x[i][j]=4;  
        } 
        break; 
      } 
      n++; 
    } 
  }    
}  
 
 
void move_up() 
{ 
  int i,j,k; 
  can_move=0; 
  for(j=0;j<4;j++) 
  { 
    for(i=0;i<4;i++) 
    { 
      if(x[i][j] == 0) 
      { 
        for(k=i+1;k<4;k++) 
        { 
          if(x[k][j] != 0) 
          { 
            x[i][j]=x[k][j]; 
            x[k][j]=0; 
            can_move=1; 
            break; 
          } 
        } 
      } 
    } 
 
 
    for(i=0;i<3;i++) 
    { 
      if(x[i][j] == x[i+1][j] && x[i][j] != 0) 
      { 
        x[i][j] *= 2; 
        x[i+1][j]=0; 
        can_move=1; 
        score += x[i][j]; 
      } 
    } 
 
    for(i=0;i<4;i++) 
    { 
      if(x[i][j] == 0) 
      { 
        for(k=i+1;k<4;k++) 
        { 
          if(x[k][j] != 0) 
          { 
            x[i][j]=x[k][j]; 
            x[k][j]=0; 
            break; 
          } 
        } 
      } 
    } 
  } 
  if(can_move == 1) 
  { 
    add(); 
  } 
}  
 
 
 
void move_down() 
{ 
  int i,j,k; 
  can_move=0; 
  for(j=0;j<4;j++) 
  { 
    for(i=3;i>=0;i--) 
    { 
      if(x[i][j] == 0) 
      { 
        for(k=i-1;k>=0;k--) 
        { 
          if(x[k][j] != 0) 
          { 
            x[i][j]=x[k][j]; 
            x[k][j]=0; 
            can_move=1; 
            break; 
          } 
        } 
      } 
    } 
 
 
    for(i=3;i>0;i--) 
    { 
      if(x[i][j] == x[i-1][j] && x[i][j] != 0) 
      { 
        x[i][j] *= 2; 
        x[i-1][j]=0; 
        can_move=1; 
        score += x[i][j]; 
      } 
    } 
 
    for(i=3;i>=0;i--) 
    { 
      if(x[i][j] == 0) 
      { 
        for(k=i-1;k>=0;k--) 
        { 
          if(x[k][j] != 0) 
          { 
            x[i][j]=x[k][j]; 
            x[k][j]=0; 
            break; 
          } 
        } 
      } 
    } 
  } 
  if(can_move == 1) 
  { 
    add(); 
  } 
 
}  
 
 
void move_left() 
{ 
  int i,j,k; 
  can_move=0; 
  for(i=0;i<4;i++) 
  { 
    for(j=0;j<4;j++) 
    { 
      if(x[i][j] == 0) 
      { 
        for(k=j+1;k<4;k++) 
        { 
          if(x[i][k] != 0) 
          { 
            x[i][j]=x[i][k]; 
            x[i][k]=0; 
            can_move=1; 
            break; 
          } 
        } 
      } 
    } 
 
 
    for(j=0;j<3;j++) 
    { 
      if(x[i][j] == x[i][j+1] && x[i][j] != 0) 
      { 
        x[i][j] *= 2; 
        x[i][j+1]=0; 
        can_move=1; 
        score += x[i][j]; 
      } 
    } 
 
    for(j=0;j<3;j++) 
    { 
      if(x[i][j] == 0) 
      { 
        for(k=j+1;k<4;k++) 
        { 
          if(x[i][k] != 0) 
          { 
            x[i][j]=x[i][k]; 
            x[i][k]=0; 
            break; 
          } 
        } 
      } 
    } 
  } 
  if(can_move == 1) 
  { 
    add(); 
  } 
}  
 
 
void move_right() 
{ 
  int i,j,k; 
  can_move=0; 
  for(i=0;i<4;i++) 
  { 
    for(j=3;j>=0;j--) 
    { 
      if(x[i][j] == 0) 
      { 
        for(k=j-1;k>=0;k--) 
        { 
          if(x[i][k] != 0) 
          { 
            x[i][j]=x[i][k]; 
            x[i][k]=0; 
            can_move=1; 
            break; 
          } 
        } 
      } 
    } 
 
 
    for(j=3;j>0;j--) 
    { 
      if(x[i][j] == x[i][j-1] && x[i][j] != 0) 
      { 
        x[i][j] *= 2; 
        x[i][j-1]=0; 
        can_move=1; 
        score += x[i][j]; 
      } 
    } 
 
    for(j=3;j>=0;j--) 
    { 
      if(x[i][j] == 0) 
      { 
        for(k=j-1;k>=0;k--) 
        { 
          if(x[i][k] != 0) 
          { 
            x[i][j]=x[i][k]; 
            x[i][k]=0; 
            break; 
          } 
        } 
      } 
    } 
  } 
  if(can_move == 1) 
  { 
    add(); 
  } 
}  
  
 
  
void out()  
{  
  int i,j; 
  system("cls");  
  for(i=0;i<10;i++)  
  {  
    if(i==0)printf("┏━━┳━━┳━━┳━━┓\n┃  ┃  ┃  ┃  ┃\n┃");  
    else if(i==8)printf("┗━━┻━━┻━━┻━━┛\n");  
    else if(i==9)printf(" SCORE:%d\n",score);  
    else if(i%2==0)printf("┣━━╋━━╋━━╋━━┫\n┃  ┃  ┃  ┃  ┃\n┃");  
    else  
    {  
      for(j=0;j<4;j++)  
      {  
        if(x[i/2][j]!=0)printf("%4d",x[i/2][j]); else printf("  ");  
        printf("┃");  
      }  
      printf("\n");  
    }  
      
  } 
  if(win()) 
  {printf("You are win!");} 
  if(!check()) 
  {printf("Game over!");} 
}  
  
 
int main()  
{  
    
  unsigned char key;  
  add(); 
  add(); 
  out();     
  while(1)  
  {  
    key = getch();        
    switch(key)  
    {  
      case 'w': move_up();    break;  
      case 'a': move_left();   break;  
      case 's': move_down();   break;  
      case 'd': move_right();  break;  
    }  
    out();  
  }  
  return 0;  
}  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C++ 多线程之互斥量(mutex)详解

    C++ 多线程之互斥量(mutex)详解

    这篇文章主要为大家详细介绍了C++多线程之互斥量(mutex),文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • 详解C 语言项目中.h文件和.c文件的关系

    详解C 语言项目中.h文件和.c文件的关系

    这篇文章主要介绍了详解C 语言项目中.h文件和.c文件的关系的相关资料,需要的朋友可以参考下
    2017-05-05
  • C语言教程之数组详解

    C语言教程之数组详解

    这篇文章主要为大家介绍了C语言教程之数组,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • C++类继承之子类调用父类的构造函数的实例详解

    C++类继承之子类调用父类的构造函数的实例详解

    这篇文章主要介绍了C++类继承之子类调用父类的构造函数的实例详解的相关资料,希望通过本文大家能够掌握C++类继承的相关知识,需要的朋友可以参考下
    2017-09-09
  • VS中scanf函数报错问题的几种解决方法

    VS中scanf函数报错问题的几种解决方法

    本文主要介绍了VS中scanf函数报错问题的几种解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • C++实现图形界面双人五子棋游戏

    C++实现图形界面双人五子棋游戏

    这篇文章主要为大家详细介绍了C++实现图形界面双人五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • C++调试追踪class成员变量的方法

    C++调试追踪class成员变量的方法

    本文所讲的是不通过修改一个class的成员,就能够追踪其成员。方法就是类似C语言中的函数指针
    2013-11-11
  • C语言数据结构中树与森林专项详解

    C语言数据结构中树与森林专项详解

    这篇文章主要介绍了C语言数据结构中树与森林,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-11-11
  • 详解C语言中双指针算法的使用

    详解C语言中双指针算法的使用

    双指针,指的是在遍历对象的过程中,不是普通的使用单个指针进行访问,而是使用两个相同方向(快慢指针)或者相反方向(对撞指针)的指针进行扫描,从而达到相应的目的。本文将通过示例带大家深入了解双指针算法的使用
    2022-08-08
  • 详解C++ 的STL迭代器原理和实现

    详解C++ 的STL迭代器原理和实现

    这篇文章主要为大家介绍了C++的STL迭代器原理和实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01

最新评论