C語(yǔ)言實(shí)現(xiàn)2048游戲
本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)2048小游戲的具體代碼,供大家參考,具體內(nèi)容如下
具有以下特點(diǎn):
1.linux下完成
2.非堵塞鍵盤(pán)讀取
3.隨機(jī)生成2和4
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#define TTY_PATH "/dev/tty"
#define STTY_ON "stty raw -echo -F"
#define STTY_OFF "stty -raw echo -F"
int map[4][4];
typedef struct node
{
int x;
int y;
int num;
}Node;
Node node;
void init_map()//初始化全部方格
{
int i, j;
for(i=0; i<4; i++)
for(j=0; j<4; j++)
map[i][j] = 0;
}
void new_node()//新增方格,避免重復(fù)。
{
int x = 0, y = 0 ,num = 0;
do{
int fals = 1;
int i,j;
for(i=0; i<4; i++)
for(j=0; j<4; j++)
if(map[i][j] == 0)
fals =0;
if(fals)//新方格無(wú)法被填入,游戲失敗
{
system("clear");
printf("game over!!!!!!!!!!!\n");
exit(0);
}
x = rand() % 4;
y = rand() % 4;
num = rand() % 2;
if(num == 0)
num = 3;
else if(num == 1)
num = 5;
}while(map[x][y] > 0);
node.x = x;
node.y = y;
node.num = num;
map[x][y] = node.num;
}
void show()//彩色打印數(shù)字
{
int i, j;
for(i=0; i<4; i++)
{
for(j=0; j<4; j++)
{
if(map[i][j]%2 == 1)
{
map[i][j] -= 1;
printf("\33[31m%d\33[0m\t",map[i][j]);
}
else if(map[i][j] == 0)
{
printf("%d\t",map[i][j]);
}
else if(map[i][j] == 2)
{
printf("\33[32m%d\33[0m\t",map[i][j]);
}
else if(map[i][j] == 4)
{
printf("\33[33m%d\33[0m\t",map[i][j]);
}
else if(map[i][j] == 8)
{
printf("\33[34m%d\33[0m\t",map[i][j]);
}
else if(map[i][j] == 16)
{
printf("\33[35m%d\33[0m\t",map[i][j]);
}
else if(map[i][j] == 32)
{
printf("\33[36m%d\33[0m\t",map[i][j]);
}
else
{
printf("\33[44m%d\33[0m\t",map[i][j]);
}
}
printf("\n");
}
}
void left()
{
int i, j, z, tmp;
for(i=0; i<4; i++)//全體方格左移
for(j=0; j<4; j++)
if(map[i][j] == 0 )
for(z = j + 1; z<4; z++)
if(map[i][z] > 0)
{
tmp = map[i][j];
map[i][j] = map[i][z];
map[i][z] = tmp;
break;
}
for(i=0; i<4; i++)//如果方格數(shù)字相同則,相加,通過(guò)主函數(shù)多次調(diào)用,排列好
for(j=0; j<4; j++)
if(map[i][j] > 0 )
for(z = j + 1; z<4; z++)
if(map[i][z] > 0)
if(map[i][z] == map[i][j])
{
map[i][j] *= 2;
map[i][z] = 0;
}else
break;
else
break;
else
break;
}
void right()
{
int i, j, z, tmp;
for(i=0; i<4; i++)
for(j=3; j>=0; j--)
if(map[i][j] == 0 )
for(z = j-1; z>=0; z--)
if(map[i][z] > 0)
{
tmp = map[i][j];
map[i][j] = map[i][z];
map[i][z] = tmp;
break;
}
for(i=0; i<4; i++)
for(j=3; j>=0; j--)
if(map[i][j] > 0 )
for(z = j-1; z>=0; z--)
if(map[i][z] > 0)
if(map[i][z] == map[i][j])
{
map[i][j] *= 2;
map[i][z] = 0;
}else
break;
else
break;
else
break;
}
void up()
{
int i, j, z, tmp;
for(i=0; i<4; i++)
for(j=0; j<4; j++)
if(map[j][i] == 0 )
for(z = j+1; z<4; z++)
if(map[z][i] > 0)
{
tmp = map[j][i];
map[j][i] = map[z][i];
map[z][i] = tmp;
break;
}
for(i=0; i<4; i++)
for(j=0; j<4; j++)
if(map[j][i] > 0 )
for(z = j+1; z<4; z++)
if(map[z][i] > 0)
if(map[z][i] == map[j][i])
{
map[j][i] *= 2;
map[z][i] = 0;
}else
break;
else
break;
else
break;
}
void down()
{
int i, j, z, tmp;
for(i=0; i<4; i++)
for(j=3; j>=0; j--)
if(map[j][i] == 0 )
for(z = j-1; z>=0; z--)
if(map[z][i] > 0)
{
tmp = map[j][i];
map[j][i] = map[z][i];
map[z][i] = tmp;
break;
}
for(i=0; i<4; i++)
for(j=3; j>=0; j--)
if(map[j][i] > 0 )
for(z = j-1; z>=0; z--)
if(map[z][i] > 0)
if(map[z][i] == map[j][i])
{
map[j][i] *= 2;
map[z][i] = 0;
}else
break;
else
break;
else
break;
}
void move(char ch)
{
switch(ch)
{
case 'a':
left();
break;
case 'd':
right();
break;
case 'w':
up();
break;
case 's':
down();
break;
}
}
char in_direct()//非堵塞輸入
{
fd_set fd;
struct timeval tv;
char ch;
FD_ZERO(&fd);
FD_SET(0, &fd);
tv.tv_sec = 0;
tv.tv_usec = 10;
if(select(1, &fd ,NULL, NULL, &tv) > 0)
{
ch = getchar();
}
return ch;
}
int main()
{
srand(time(NULL));
init_map();
new_node();
show();
char ch;
int i=0;
while(1)
{
system(STTY_ON TTY_PATH);
ch = in_direct();
system(STTY_OFF TTY_PATH);
if(ch=='a'||ch=='d'||ch=='s'||ch=='w')
{
system("clear");
for(i=0;i<3;i++)//重復(fù)多次才能排序好
move(ch);
new_node();
show();
}
if(ch=='q')//退出游戲
{
system("clear");
printf("game over!!!!!!!!\n");
break;
}
usleep(500000);
}
return 0;
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++動(dòng)態(tài)內(nèi)存分配(new/new[]和delete/delete[])詳解
這篇文章主要介紹了C++動(dòng)態(tài)內(nèi)存分配(new/new[]和delete/delete[])詳解的相關(guān)資料,需要的朋友可以參考下2017-05-05
C語(yǔ)言基于圖形庫(kù)實(shí)現(xiàn)雙人貪吃蛇
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言基于圖形庫(kù)實(shí)現(xiàn)雙人貪吃蛇,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
C/C++中的?Qt?StandardItemModel?數(shù)據(jù)模型應(yīng)用解析
QStandardItemModel?是標(biāo)準(zhǔn)的以項(xiàng)數(shù)據(jù)為單位的基于M/V模型的一種標(biāo)準(zhǔn)數(shù)據(jù)管理方式,本文給大家介紹C/C++中的?Qt?StandardItemModel?數(shù)據(jù)模型應(yīng)用解析,感興趣的朋友跟隨小編一起看看吧2021-12-12
C語(yǔ)言實(shí)現(xiàn)輸出平均成績(jī)最高學(xué)生的信息
這篇文章主要介紹利用C語(yǔ)言實(shí)現(xiàn)輸出平均成績(jī)最高學(xué)生的信息,文章舉例說(shuō)明并附有詳細(xì)代碼,需要的朋友可以參考一下2021-10-10
C語(yǔ)言結(jié)構(gòu)體內(nèi)存對(duì)齊詳解
大家好,本篇文章主要講的是C語(yǔ)言結(jié)構(gòu)體內(nèi)存對(duì)齊詳解,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2022-01-01
C++實(shí)現(xiàn)簡(jiǎn)單校園導(dǎo)游系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單校園導(dǎo)游系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03

