简单实现C语言2048游戏

所属分类: 软件编程 / C 语言 阅读数: 67
收藏 0 赞 0 分享

本文实例为大家分享了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语言来求最大连续子序列乘积的方法

这篇文章主要介绍了利用C语言来求最大连续子序列乘积的方法,基本的思路以外文中还附有相关ACM题目,需要的朋友可以参考下
收藏 0 赞 0 分享

用C语言判断一个二叉树是否为另一个的子结构

这篇文章主要介绍了用C语言判断一个二叉树是否为另一个的子结构,是数据结构学习当中的基础知识,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言实现的阶乘,排列和组合实例

这篇文章主要介绍了C语言实现的阶乘,排列和组合的方法,涉及C语言数学运算的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言查找数组里数字重复次数的方法

这篇文章主要介绍了C语言查找数组里数字重复次数的方法,涉及C语言针对数组的遍历与判断技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言简单实现计算字符个数的方法

这篇文章主要介绍了C语言简单实现计算字符个数的方法,涉及C语言针对字符串的简单遍历与判定技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

c实现linux下的数据库备份

本文给大家简单介绍下c实现linux下的数据库备份的方法和具体的源码,十分的实用,有需要的小伙伴可以参考下。
收藏 0 赞 0 分享

C++获得文件状态信息的方法

这篇文章主要介绍了C++获得文件状态信息的方法,包括文件状态信息、文件所在磁盘盘符、文件创建时间、访问时间及修改日期等,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言按关键字搜索文件夹中文件的方法

这篇文章主要介绍了C语言按关键字搜索文件夹中文件的方法,涉及C语言文件操作及字符串查找的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享

C语言之字符串模糊查询方法的实现

本篇文章主要为大家介绍字符串模糊查询的C语言程序编写方法,有需要的朋友可以参考下
收藏 0 赞 0 分享

C语言实现BMP转换JPG的方法

这篇文章主要介绍了C语言实现BMP转换JPG的方法,涉及C#图片格式转换的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
收藏 0 赞 0 分享
查看更多