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

基于C語言實(shí)現(xiàn)2048游戲

 更新時間:2021年10月28日 17:12:12   作者:-林澤宇  
這篇文章主要為大家詳細(xì)介紹了基于C語言實(shí)現(xiàn)2048游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C語言實(shí)現(xiàn)2048游戲的具體代碼,供大家參考,具體內(nèi)容如下

#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <conio.h>
#include <windows.h>

#define ROW 4
#define COL ROW

#define KEY1           224
#define KEY_LEFT    75
#define KEY_UP       72
#define KEY_RIGHT 77
#define KEY_DOWN 80

int g_sgap = 0;

/*
應(yīng)用市場下載2048
如果需要圖形界面,需要加界面庫
*/

//在數(shù)組arr產(chǎn)生一個新的數(shù)字
void GetNewVal(int arr[ROW][COL])
{
 srand( (unsigned)time( NULL ) + g_sgap++);
 int x = rand()%ROW;//行下標(biāo),保證不越界
 int y = rand()%COL;//列下標(biāo),保證不越界

 int newval = 2;
 if(x == 0)//75%的概率為2,25%的概率為4
 {
  newval = 4;
 }

 //找到空閑的格子
 while(arr[x][y] != 0)//該格子已經(jīng)有值,todo有可能死循環(huán)
 {
  y++;
  if(y == COL)//
  {
   y = 0;
   x = (x+1)%ROW;//下一行
  }
 }

 arr[x][y] = newval;
}

//打印
void Show(int arr[ROW][COL])
{
 system("cls");
 for(int i=0; i<ROW;i++)
 {
  for(int j=0;j<COL;j++)
  {
   printf("%4d",arr[i][j]);
  }
  printf("\n");
 }
}

//顯示開始界面
void Start(int arr[ROW][COL])
{
 //獲取兩個數(shù)字,然后顯示界面
 GetNewVal(arr);
 GetNewVal(arr);

 Show(arr);
}

//獲取鍵值,左:1,上:2,右:3,下:4,其它:0
int GetButton()
{
 int key1 = 0;//第一個鍵值
 int key2 = 0;//第二個鍵值
 while(1)
 {
  if(_kbhit())
  {
   key1 = _getch();//獲得第一個鍵值
   if(key1 == KEY1)//0xE0
   {
    key2 = _getch();//獲取第二個鍵值
    if(key2 == KEY_LEFT)
    {
     return 1;
    }
    else if(key2 == KEY_UP)
    {
     return 2;
    }
    else if(key2 == KEY_RIGHT)
    {
     return 3;
    }
    else if(key2 == KEY_DOWN)
    {
     return 4;
    }
   }
  }
  Sleep(100);//睡眠,讓出CPU,避免忙等待
 }
}

//向左合并
bool MergeLeft(int arr[ROW][COL])
{
 int x1 = -1;//第一個需要合并的數(shù)字下標(biāo)
 
 bool flg = false;//當(dāng)前沒有有效合并(沒有數(shù)據(jù)合并,也沒有數(shù)據(jù)移動)

 for(int i=0;i<ROW;i++)
 {
  x1 = -1;
  //第一步,合并相同的數(shù)字
  for(int j=0;j<COL;j++)
  {
   if(arr[i][j]!=0)
   {
    if(x1 == -1)//該行第一個非0的值
    {
     x1 = j;
    }
    else//當(dāng)前第二個需要處理的值
    {
     if(arr[i][j] == arr[i][x1])//合并,將x1下標(biāo)的值*2,j下標(biāo)的值置為0
     {
      arr[i][x1] *= 2;
      arr[i][j] = 0;
      x1 = -1;
      flg = true;
     }
     else//第一個值和第二個值不等,
     {
      x1 = j;
     }
    }
   }

  }

  //第二步,移動數(shù)字
  int index = 0;//當(dāng)前可以放數(shù)據(jù)的下標(biāo)
  for(int j=0;j<COL;j++)
  {
   if(arr[i][j]!=0)//需要移動數(shù)據(jù)
   {
    if(index != j)
    {
     arr[i][index] = arr[i][j];
     arr[i][j] = 0;
     index++;
     flg = true;
    }
    else
    {
     index++;
    }
   }
  }
 }
 return flg;
}

//游戲是否結(jié)束
//1.沒有空閑單元格
//2.相鄰沒有相同的數(shù)字
bool IsGameOver(int arr[ROW][COL])
{
 //判斷有沒有空閑單元格
 int activeCell = 0;//統(tǒng)計(jì)空閑單元格數(shù)量
 for(int i=0;i<ROW;i++)
 {
  for(int j=0;j<COL;j++)
  {
   if(arr[i][j] == 0)
   {
    activeCell++;
   }
  }
 }
 if(activeCell != 0)
 {
  return false;
 }

 //相鄰是否有相同的數(shù)字,只需要判斷右邊和下邊
 for(int i=0;i<ROW;i++)
 {
  for(int j=0;j<COL;j++)
  {
   //if(arr[i][j]==arr[i][j+1] || arr[i][j] == arr[i+1][j])
   if(j+1<COL&&arr[i][j]==arr[i][j+1] || i+1<ROW&&arr[i][j]==arr[i+1][j])
   {
    return false;
   }
  }
 }
 return true;
}

void Run(int arr[ROW][COL])
{
 int bt;
 bool rt = false;
 while(1)
 {
  bt = GetButton();

  if(bt == 1)//方向鍵左
  {
   rt = MergeLeft(arr);
   if(rt)
   {
    GetNewVal(arr);
    Show(arr);
    if(IsGameOver(arr))
    {
     return ;
    }
   }
  }
 }

}

int main()
{
 int arr[ROW][COL] = {0};

 Start(arr);

 Run(arr);

 return 0;
}


int main1()
{
 int a = 0;
 while(1)
 {
  if(_kbhit())
  {
   a = _getch();//getchar();
   printf("鍵值是:%d\n",a);
  }
 }
 return 0;
}


/*
int main()
{
 srand( (unsigned)time( NULL ) );


 for(int i=0;i<10;i++)
 {
  printf("%d ",rand());
 }
 printf("\n");

 return 0;
}
*/

運(yùn)行畫面

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++中opencv4.1.0環(huán)境配置的詳細(xì)過程

    C++中opencv4.1.0環(huán)境配置的詳細(xì)過程

    這篇文章主要介紹了C++中opencv4.1.0環(huán)境配置的詳細(xì)過程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • c++ dynamic_cast與static_cast使用方法示例

    c++ dynamic_cast與static_cast使用方法示例

    本文用示例講解了dynamic_cast、static_cast子類與基類之間轉(zhuǎn)換功能的使用方法
    2013-11-11
  • 淺談幾種常見語言的命名空間(Namespace)

    淺談幾種常見語言的命名空間(Namespace)

    本文給大家簡單介紹了下幾種常見語言的命名空間的特性以及簡單示例,大家對比下,有需要的小伙伴可以參考下
    2016-03-03
  • C++ 冒泡排序數(shù)據(jù)結(jié)構(gòu)、算法及改進(jìn)算法

    C++ 冒泡排序數(shù)據(jù)結(jié)構(gòu)、算法及改進(jìn)算法

    冒泡排序是一種簡單排序。這種排序是采用“冒泡策略”將最大元素移到最右邊。在冒泡過程中,相鄰兩個元素比較,如果左邊大于右邊的,則進(jìn)行交換兩個元素。這樣一次冒泡后,可確保最大的在最右邊。然后執(zhí)行n次冒泡后排序即可完畢
    2013-04-04
  • C++命名空間實(shí)例詳解

    C++命名空間實(shí)例詳解

    這篇文章主要介紹了C++命名空間實(shí)例詳解,有感興趣的同學(xué)可以研究下
    2021-02-02
  • C語言實(shí)現(xiàn)3*3數(shù)組對角線之和示例

    C語言實(shí)現(xiàn)3*3數(shù)組對角線之和示例

    今天小編就為大家分享一篇C語言實(shí)現(xiàn)3*3數(shù)組對角線之和示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12
  • C語言冷知識之預(yù)處理字符串操作符詳解

    C語言冷知識之預(yù)處理字符串操作符詳解

    當(dāng)年學(xué)習(xí)C語言的第一門課就提到過標(biāo)記(Token)的概念,不過,相信在多年之后你再次聽到這個術(shù)語時會一臉懵逼,比如我。因此特地翻了翻資料,整理下來這些筆記,希望對大家有所幫助
    2022-11-11
  • C語言函數(shù)調(diào)用約定和返回值詳情

    C語言函數(shù)調(diào)用約定和返回值詳情

    這篇文章主要介紹了C語言函數(shù)調(diào)用約定和返回值詳情,函數(shù)調(diào)用約定不同,會影響函數(shù)生成的符號名,函數(shù)入?yún)㈨樞?,形參?nèi)存的清理者,更多相關(guān)需要的小伙伴可以參考下文詳情介紹
    2022-07-07
  • C++讀取文件的四種方式總結(jié)

    C++讀取文件的四種方式總結(jié)

    C++可以根據(jù)不同的目的來選取文件的讀取方式,C++中有四種常見的讀取方式,本文主要介紹了這四種方法的具體實(shí)現(xiàn),需要的可以參考一下
    2023-04-04
  • C語言實(shí)現(xiàn)繪制可愛的橘子鐘表

    C語言實(shí)現(xiàn)繪制可愛的橘子鐘表

    這篇文章主要為大家詳細(xì)介紹了如何利用C語言實(shí)現(xiàn)繪制可愛的橘子鐘表,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價值,感興趣的可以了解一下
    2022-12-12

最新評論