2048小游戏

原创 2015年11月21日 18:04:51

以下特点

1.linux下完成

2.非堵塞键盘读取

3.随机生成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()//新增方格,避免重复。
{
	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)//新方格无法被填入,游戏失败
	{
		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()//彩色打印数字
{
	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++)//如果方格数字相同则,相加,通过主函数多次调用,排列好
		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++)//重复多次才能排序好
				move(ch);
			new_node();
			show();
			
		}
		if(ch=='q')//退出游戏
		{
			system("clear");
			printf("game over!!!!!!!!\n");
			break;
		}
		usleep(500000);
	}
	return 0;
}


安卓模仿2048小游戏

2048是最近比较火的小游戏,算法逻辑并不难,界面简单,本项目是模仿2048的简易升级版,欢迎大家查看。 话不多说,直接开撸!...
  • Json_Jerry
  • Json_Jerry
  • 2016年10月18日 20:08
  • 1046

用原生js写2048小游戏

2048-game         #game {       display: none;       position: absolute;       left: 0px; ...
  • github_30778587
  • github_30778587
  • 2017年03月20日 03:15
  • 274

java小游戏2048实现

上课的时候见一女童鞋在玩一个叫2048的游戏,其实我是觉得玩游戏挺无聊的, 上去对她说:“这有什么好玩的咯!,太幼稚了,我都能写一个”  谁知道她来一句:“好啊,你写一个我就玩你的不玩这个了!” 既然...
  • jackjyy
  • jackjyy
  • 2015年02月26日 13:24
  • 3011

用C++语言实现小游戏2048

2048小游戏的C++实现
  • snake29
  • snake29
  • 2016年05月27日 10:05
  • 927

详解matlab之简易2048制作

详解matlab之简易2048制作详解matlab之简易2048制作 一制作之前 1关于初始化 2运行时出现2的位置问题 3移动方向问题 4关于数字合并 5关于游戏怎么结束 6其他还有什么就看着需要办...
  • on2way
  • on2way
  • 2015年05月11日 15:09
  • 4142

C++实现2048小游戏(控制台版的)

无聊,在公司写了个2048小游戏的程序,聊以自娱。(事实是我手机坏了,没得玩)。 很简单,直接上代码了。 #include #include #include using namesp...
  • tan362021334
  • tan362021334
  • 2015年03月13日 13:51
  • 10653

2048小游戏(Java)源码解析及源代码打包

数据结构课程设计写的2048小游戏,答辩完了就开源了,因为这次的技术文档任性地写成了傻瓜式教程了,就干脆也放出来了,供参考,源代码打包在最后面会附上。 一 实现方案 二 具体代码及程序框图分析 三 参...
  • KevinWu93
  • KevinWu93
  • 2015年05月18日 23:01
  • 18599

java高仿2048游戏代码

原文:java高仿2048游戏代码 源代码下载地址:http://www.zuidaima.com/share/1820781183028224.htm 直接上代码 package...
  • yaerfeng
  • yaerfeng
  • 2016年07月14日 09:57
  • 4793

学Android--实现2048小游戏

1、游戏布局(activity_main.xml) 首先在xml文件中实现游戏的整体布局 (1)添加两个TextView用来显示分数 ...
  • jxl1994
  • jxl1994
  • 2017年02月04日 23:08
  • 780

Python实现小游戏--2048

正文 本次是我对于Python实现2048这个曾经风靡一时的小游戏的代码解读 工作环境 一、主逻辑图 逻辑图解:黑色是逻辑层,蓝色是外部方法,红色是类内方法,稍...
  • python233
  • python233
  • 2017年05月10日 18:04
  • 1015
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:2048小游戏
举报原因:
原因补充:

(最多只允许输入30个字)