基于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ì)過程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10c++ dynamic_cast與static_cast使用方法示例
本文用示例講解了dynamic_cast、static_cast子類與基類之間轉(zhuǎn)換功能的使用方法2013-11-11C++ 冒泡排序數(shù)據(jù)結(jié)構(gòu)、算法及改進(jìn)算法
冒泡排序是一種簡單排序。這種排序是采用“冒泡策略”將最大元素移到最右邊。在冒泡過程中,相鄰兩個元素比較,如果左邊大于右邊的,則進(jìn)行交換兩個元素。這樣一次冒泡后,可確保最大的在最右邊。然后執(zhí)行n次冒泡后排序即可完畢2013-04-04C語言實(shí)現(xiàn)3*3數(shù)組對角線之和示例
今天小編就為大家分享一篇C語言實(shí)現(xiàn)3*3數(shù)組對角線之和示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12