欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

簡單實現(xiàn)C語言2048游戲

 更新時間:2018年05月05日 10:34:03   作者:jiayouliying  
這篇文章主要為大家詳細介紹了簡單實現(xiàn)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++ 字符串去重排序實例代碼

    C++ 字符串去重排序實例代碼

    這篇文章主要介紹了C++ 字符串去重排序實例代碼的相關資料,需要的朋友可以參考下
    2017-05-05
  • C語言實現(xiàn)小學生考試系統(tǒng)

    C語言實現(xiàn)小學生考試系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)小學生考試系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-03-03
  • 詳解C語言函數(shù)返回值解析

    詳解C語言函數(shù)返回值解析

    這篇文章主要介紹了詳解C語言函數(shù)返回值解析的相關資料,需要的朋友可以參考下
    2017-06-06
  • QT 中文亂碼解決匯總(QString與string、char*互轉亂碼)

    QT 中文亂碼解決匯總(QString與string、char*互轉亂碼)

    在QT中使用中文時,經常會碰到論碼問題,本文主要介紹了QT 中文亂碼解決匯總(QString與string、char*互轉亂碼),需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • 淺談QT內存泄漏

    淺談QT內存泄漏

    本文主要介紹了淺談QT內存泄漏,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • C語言柔性數(shù)組的實現(xiàn)示例

    C語言柔性數(shù)組的實現(xiàn)示例

    柔性數(shù)組既數(shù)組大小待定的數(shù)組, C語言中結構體的最后一個元素可以是大小未知的數(shù)組,本文就來介紹一下柔性數(shù)組的用法,感興趣的可以了解一下
    2024-03-03
  • C++實現(xiàn)LeetCode(163.缺失區(qū)間)

    C++實現(xiàn)LeetCode(163.缺失區(qū)間)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(163.缺失區(qū)間),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-07-07
  • Qt生成隨機數(shù)的方法

    Qt生成隨機數(shù)的方法

    本文主要介紹了Qt生成隨機數(shù),生成隨機數(shù)主要用到了函數(shù)qsrand和qrand,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 純C++代碼詳解二叉樹相關操作

    純C++代碼詳解二叉樹相關操作

    二叉樹(Binary?tree)是樹形結構的一個重要類型。許多實際問題抽象出來的數(shù)據(jù)結構往往是二叉樹形式。本文將通過代碼為大家詳細講講C++二叉樹的一些常規(guī)操作,感興趣的可以學習一下
    2022-07-07
  • 一波C語言二元查找樹算法題目解答實例匯總

    一波C語言二元查找樹算法題目解答實例匯總

    這篇文章主要介紹了一波C語言二元查找樹算法題目解答實例匯總,包括按層次遍歷和轉換為鏡像等基本算法題目,需要的朋友可以參考下
    2016-03-03

最新評論