简单实现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;  
}  

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

相关文章

  • OpenCV实现图像膨胀

    OpenCV实现图像膨胀

    这篇文章主要为大家详细介绍了OpenCV实现图像膨胀,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06
  • C++中new与delete、malloc与free应用分析

    C++中new与delete、malloc与free应用分析

    这篇文章主要介绍了C++中new与delete、malloc与free应用分析,很重要的概念,需要的朋友可以参考下
    2014-08-08
  • C++实现LeetCode(134.加油站问题)

    C++实现LeetCode(134.加油站问题)

    这篇文章主要介绍了C++实现LeetCode(134.加油站问题),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C语言长字符串的换行方法详解

    C语言长字符串的换行方法详解

    在编写C程序时,如果想要打印某个字符串,而字符串的内容比较多,这就涉及到对这个长字符串进行书写换行,本片文章就带你了解一下
    2021-09-09
  • C++详解默认参数的构造函数及简单实例代码

    C++详解默认参数的构造函数及简单实例代码

    这篇文章主要介绍了 C++详解默认参数的构造函数及简单实例代码的相关资料,需要的朋友可以参考下
    2017-02-02
  • C++实现CreatThread函数主线程与工作线程交互的方法

    C++实现CreatThread函数主线程与工作线程交互的方法

    这篇文章主要介绍了C++实现CreatThread函数主线程与工作线程交互的方法,是Windows应用程序设计中非常实用的方法,需要的朋友可以参考下
    2014-10-10
  • 一篇文章带你入门C语言:函数

    一篇文章带你入门C语言:函数

    这篇文章主要介绍了C语言中函数的声明、定义及使用的入门教程,重点讲述了main函数的相关知识,需要的朋友可以参考下,希望能给你带来帮助
    2021-08-08
  • 浅析bilateral filter双边滤波器的理解

    浅析bilateral filter双边滤波器的理解

    这篇文章主要介绍了bilateral filter双边滤波器的通俗理解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • C和C++中argc和argv的含义及用法详解

    C和C++中argc和argv的含义及用法详解

    argv 是 argument vector的缩写,表示传入main函数的参数序列或指针,这篇文章主要介绍了C和C++中argc和argv的含义以及用法,需要的朋友可以参考下
    2022-11-11
  • C++线程安全容器stack和queue的使用详细介绍

    C++线程安全容器stack和queue的使用详细介绍

    stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行 元素的插入与提取操作;队列是一种容器适配器,专门用于在FIFO上下文(先进先出)中操作,其中从容器一端插入元素,另一端提取元素
    2022-08-08

最新评论