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

C語言實現(xiàn)2048游戲(ege圖形庫版)

 更新時間:2018年12月21日 16:16:53   作者:什么都只會一點點  
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)2048游戲,ege圖形庫版,具有一定的參考價值,感興趣的小伙伴們可以參考一下

這幾天看到我們班上一個大神寫了一個2048出來,我自己也想嘗試一下,經(jīng)過幾天自己嘗試努力下,自己終于寫出來了。現(xiàn)在和大家分享一下,也希望能得到大神的指點。

實現(xiàn)的效果如圖

先來講一下我的思路吧

1.首先肯定是要一個4X4的二維數(shù)組來存放數(shù)字存放0、2、4……
2.游戲開始與過程中需要隨機(jī)出現(xiàn)2或者4,所以需要調(diào)用time.h這個庫
3.游戲開始時,假如當(dāng)獲取字符為‘w'則先用循環(huán)判定這個數(shù)字的下方有無和它相等的數(shù)字。如無則跳過,如有相加。然后在判定是否可以向上移動

下面是我的代碼

(我本來是還要寫一個撤回的函數(shù) 可惜寫出來卻不能運行。求大神指教)

#include<stdio.h>
//#include<conio.h>
#include<graphics.h>
#include<Windows.h>
#include<time.h>
int _back[4][4] = {};
void draw();//繪圖
void play();
void init();//初始化數(shù)字
void _up();//向上移動
void _down();//向下移動
void _left();//像左移動
void _right();//向右移動
void add_number();//增加一個數(shù)字
int a[4][4] = { 0 };
int emtpy;
//空格的數(shù)量
void draw()
{
  int i, j;
  for (i = 0; i < 4; i++)
  {
    for (j = 0; j < 4; j++)
    {
      _back[i][j] = a[i][j];
      PIMAGE img;
      img = newimage();
      switch (a[i][j])
      {
      case 0:
      {
        getimage(img, "2048\\0.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 2:
      {
        getimage(img, "2048\\2.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 4:
      {
        getimage(img, "2048\\4.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 8:
      {
        getimage(img, "2048\\8.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 16:
      {
        getimage(img, "2048\\16.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 32:
      {
        getimage(img, "2048\\32.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 64:
      {
        getimage(img, "2048\\64.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 128:
      {
        getimage(img, "2048\\128.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 256:
      {
        getimage(img, "2048\\256.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 512:
      {
        getimage(img, "2048\\512.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 1024:
      {
        getimage(img, "2048\\1024.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      case 2048:
      {
        getimage(img, "2048\\2048.png");
        putimage(j * 180, i * 180, img);
        break;
      }
      }
    }
  }

}
void init()
{
  int x, y;
  srand(time(0));
  x = rand() % 4;
  y = rand() % 4;
  a[x][y] = 2;
  emtpy = 15;

}
void _up()
{
  int x, y, i;

  for (y = 0; y < 4; ++y) {   // 從上向下合并相同的方塊 
    for (x = 0; x < 4; ++x) {
      if (a[x][y] == 0)
        ;
      else {
        for (i = x + 1; i < 4; ++i) {
          if (a[i][y] == 0)
            ;
          else if (a[x][y] == a[i][y]) {
            a[x][y] += a[i][y];
            a[i][y] = 0;
            ++emtpy;
            x = i;
            break;

          }
          else {

            break;
          }
        }
      }
    }
  }

  for (y = 0; y < 4; ++y)  // 向上移動箱子
    for (x = 0; x < 4; ++x)
    {
      if (a[x][y] == 0)
        ;
      else {
        for (i = x; (i > 0) && (a[i - 1][y] == 0); --i) {
          a[i - 1][y] = a[i][y];
          a[i][y] = 0;
        }
      }
    }
}
void _down() {
  int x, y, i;

  for (y = 0; y < 4; ++y) // 向下合并相同的方格 
    for (x = 3; x >= 0; --x) {
      if (a[x][y] == 0)
        ;
      else {
        for (i = x - 1; i >= 0; --i) {
          if (a[i][y] == 0)
            ;
          else if (a[x][y] == a[i][y]) {
            a[x][y] += a[i][y];
            a[i][y] = 0;
            ++emtpy;
            x = i;
            break;
          }
          else
            break;
        }
      }
    }

  for (y = 0; y < 4; ++y) // 向下移動方格 
    for (x = 3; x >= 0; --x) {
      if (a[x][y] == 0)
        ;
      else {
        for (i = x; (i < 3) && (a[i + 1][y] == 0); ++i) {
          a[i + 1][y] = a[i][y];
          a[i][y] = 0;
        }
      }
    }
}
void _left()
{
  int x, y, i;

  for (x = 0; x < 4; ++x)  // 向左合并相同的方格 
    for (y = 0; y < 4; ++y) {
      if (a[x][y] == 0)
        ;
      else {
        for (i = y + 1; i < 4; ++i) {
          if (a[x][i] == 0)
            ;
          else if (a[x][y] == a[x][i]) {
            a[x][y] += a[x][i];
            a[x][i] = 0;
            emtpy++;
            y = i;
            break;
          }
          else
            break;
        }
      }
    }

  for (x = 0; x < 4; ++x) // 向左移動方格 
    for (y = 0; y < 4; ++y) {
      if (a[x][y] == 0)
        ;
      else {
        for (i = y; (i > 0) && (a[x][i - 1] == 0); --i) {
          a[x][i - 1] = a[x][i];
          a[x][i] = 0;
        }
      }
    }
}
void _right() {
  int x, y, i;

  for (x = 0; x < 4; ++x) // 向右合并相同的方格 
    for (y = 3; y >= 0; --y) {
      if (a[x][y] == 0)
        ;
      else {
        for (i = y - 1; i >= 0; --i) {
          if (a[x][i] == 0)
            ;
          else if (a[x][y] == a[x][i]) {
            a[x][y] += a[x][i];
            a[x][i] = 0;
            ++emtpy;
            y = i;
            break;
          }
          else
            break;
        }
      }
    }

  for (x = 0; x < 4; ++x)  // 向右移動方格 
    for (y = 3; y >= 0; --y) {
      if (a[x][y] == 0)
        ;
      else {
        for (i = y; (i < 3) && (a[x][i + 1] == 0); ++i) {
          a[x][i + 1] = a[x][i];
          a[x][i] = 0;
        }
      }
    }
}
void add_number()
{
  srand(time(0));
  if (emtpy > 0)
  {
    int x, y, temp;
    do
    {
      x = rand() % 4;
      y = rand() % 4;
    } while (a[x][y] != 0);
    temp = rand();
    int i = temp % 2;
    if (i == 1)
    {
      a[x][y] = 2;
      emtpy--;

    }
    else
    {
      a[x][y] = 4;
      emtpy--;
    }

  }
}
void play()
{
  char c = getch();
  switch (c)
  {
  case 'w':
  case'W':
  {
    _up();
    add_number();
    draw();

    break;

  }
  case 's':
  case'S':
  {
    _down();
    add_number();
    draw();
    break;

  }
  case 'a':
  case'A':
  {
    _left();
    add_number();
    draw();
    break;



  }case 'd':
  case'D':
  {
    _right();
    add_number();
    draw();
    break;

  }
  case 'q':
  case 'Q':
  {
    for (int i = 0; i < 4; i++)
    {
      for (int j = 0; j < 4; j++)
      {
        a[i][j] = _back[i][j];
        draw();
      }
    }
  }
  }

}
int main()
{
  init();
  int i, j;
  initgraph(724, 724);//初始化
  PIMAGE img;
  img = newimage();
  getimage(img, "2048/背景.jpg");
  putimage(0, 0, img);
  draw();
  for (; is_run(); delay_fps(30))
  {
    for (int i = 0; i < 4; i++)
    {
      for (int j = 0; j < 4; j++)
      {
        _back[i][j] = a[i][j];
      }
    }
    play();
  }
}

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

相關(guān)文章

  • C語言 詳細(xì)分析結(jié)構(gòu)體的內(nèi)存對齊

    C語言 詳細(xì)分析結(jié)構(gòu)體的內(nèi)存對齊

    C 數(shù)組允許定義可存儲相同類型數(shù)據(jù)項的變量,結(jié)構(gòu)是 C 編程中另一種用戶自定義的可用的數(shù)據(jù)類型,它允許你存儲不同類型的數(shù)據(jù)項,本篇讓我們來了解C 的結(jié)構(gòu)體內(nèi)存對齊
    2022-03-03
  • C語言實踐設(shè)計開發(fā)飛機(jī)游戲

    C語言實踐設(shè)計開發(fā)飛機(jī)游戲

    飛機(jī)大戰(zhàn)想必是很多人童年時期的經(jīng)典游戲,我們依舊能記得抱個老人機(jī)娛樂的場景,下面這篇文章主要給大家介紹了關(guān)于如何利用C語言寫一個簡單的飛機(jī)大戰(zhàn)小游戲的相關(guān)資料,需要的朋友可以參考下
    2022-02-02
  • C++實現(xiàn)猜數(shù)游戲

    C++實現(xiàn)猜數(shù)游戲

    這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)猜數(shù)游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • 淺析成員函數(shù)和常成員函數(shù)的調(diào)用

    淺析成員函數(shù)和常成員函數(shù)的調(diào)用

    下面小編就為大家?guī)硪黄獪\析成員函數(shù)和常成員函數(shù)的調(diào)用。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考,一起跟隨小編過來看看吧
    2016-05-05
  • 枚舉類型的定義和應(yīng)用總結(jié)

    枚舉類型的定義和應(yīng)用總結(jié)

    如果一種變量只有幾種可能的值,可以定義為枚舉類型。所謂“枚舉類型”是將變量的值一一列舉出來,變量的值只能在列舉出來的值的范圍內(nèi)
    2013-10-10
  • Qt在線安裝加速的實現(xiàn)

    Qt在線安裝加速的實現(xiàn)

    本文主要介紹了Qt在線安裝加速的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-02-02
  • C++學(xué)習(xí)之異常機(jī)制詳解

    C++學(xué)習(xí)之異常機(jī)制詳解

    C++中的異常處理機(jī)制可以幫助我們處理程序在運行時可能會遇到的異常情況,比如內(nèi)存分配錯誤、文件打開失敗等。本文就和大家詳細(xì)講講C++中異常機(jī)制的具體使用吧
    2023-04-04
  • C++二分查找算法實例

    C++二分查找算法實例

    這篇文章主要為大家詳細(xì)介紹了C++二分查找算法的實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 如何將C語言代碼轉(zhuǎn)換為應(yīng)用程序(也就是編譯)

    如何將C語言代碼轉(zhuǎn)換為應(yīng)用程序(也就是編譯)

    有時候我們將讓我們的c語言代碼保存為一個exe方便,方便使用,實際就是我們俗說的編譯
    2013-07-07
  • QT+OpenGL實現(xiàn)簡單圖形的繪制

    QT+OpenGL實現(xiàn)簡單圖形的繪制

    這篇文章主要為大家詳細(xì)介紹了如何利用QT和OpenGL實現(xiàn)簡單圖形的繪制,文中的示例代碼講解詳細(xì),具有一定的借鑒價值,需要的可以參考一下
    2022-12-12

最新評論