#include <stdio.h>
#include <stdlib.h>
#include <curses.h>
#include <time.h>
#include <unistd.h>
#include <signal.h> // 4*4方格
int a[][] = {};
// 方格里空格的个数
int empty;
int old_y, old_x; void draw();
void play();
void init();
void draw_one(int y, int x);
void cnt_value(int *new_y, int *new_x);
int game_over();
int cnt_one(int y, int x); int main()
{
init();
play();
endwin(); return ;
} void init()
{
int x, y; initscr();
cbreak();
noecho();
curs_set(); empty = ;
srand(time());
x = rand() % ;
y = rand() % ;
a[y][x] = ;
draw();
} void draw()
{
int n, m, x, y;
char c[] = {'', '', '', ''}; clear();
for(n = ; n < ; n += ) //横线
for(m = ; m < ; m++) {
move(n, m);
addch('-');
refresh();
}
for(m = ; m < ; m += ) //竖线
for(n = ; n < ; n++) {
move(n, m);
addch('|');
refresh();
}
for(y = ; y < ; y++) //数字
for(x = ; x < ; x++) {
draw_one(y, x);
}
} void draw_one(int y, int x)
{
int i, m, k, j;
char c[] = {'', '', '', ''}; i = a[y][x];
m = ;
do {
j = i % ;
c[m++] = j + '';
i = i / ;
}while(i > );
m = ;
k = (x + ) * - ;
while(c[m] != '') {
move(*y+, k);
addch(c[m++]);
k--;
}
} void play()
{
int x, y, i, new_x, new_y, tmp;
int old_empty, move;
char ch; while() {
move = ;
old_empty = empty;
//draw();
ch = getch();
switch(ch) {
case 'A':
case 'a':
//从左向右消去相同方块
for(y = ; y < ; y++)
for(x = ; x < ; ) {
if(a[y][x] == ) {
x++;
continue;
} else {
for(i = x + ; i < ; i++) {
if(a[y][i] == ) {
continue;
}
else {
if(a[y][x] == a[y][i]) {
a[y][x] += a[y][i];
a[y][i] = ;
x = i + ;
empty++;
break;
}
else {
x = i;
break;
}
}
}
x = i;
}
}
//向左移动方块
for(y = ; y < ; y++)
for(x = ; x < ; x++) {
if(a[y][x] == ) {
continue;
} else {
for(i = x; (i > ) && (a[y][i-] == ); i--) {
a[y][i-] = a[y][i];
a[y][i] = ;
move = ;
}
}
}
break;
case 'D':
case 'd':
//从右向左消去相同方块
for(y = ; y < ; y++)
for(x = ; x >= ; ) {
if(a[y][x] == ) {
x--;
continue;
} else {
for(i = x - ; i >= ; i--) {
if(a[y][i] == ) {
continue;
} else if(a[y][x] == a[y][i]) {
a[y][x] += a[y][i];
a[y][i] = ;
x = i - ;
empty++;
break;
} else {
x = i;
break;
}
}
x = i;
}
}
//向右移动方块
for(y = ; y < ; y++)
for(x = ; x >= ; x--) {
if(a[y][x] == ) {
continue;
} else {
for(i = x; (i < ) && (a[y][i+] == ); i++) {
a[y][i+] = a[y][i];
a[y][i] = ;
move = ;
}
}
}
break;
case 'W':
case 'w':
//从上向下消去相同方块
for(x = ; x < ; x++)
for(y = ; y < ; ) {
if(a[y][x] == ) {
y++;
continue;
} else {
for(i = y + ; i < ; i++) {
if(a[i][x] == ) {
continue;
} else if(a[y][x] == a[i][x]) {
a[y][x] += a[i][x];
a[i][x] = ;
y = i + ;
empty++;
break;
} else {
y = i;
break;
}
}
y = i;
}
}
//向上移动方块
for(x = ; x < ; x++)
for(y = ; y < ; y++) {
if(a[y][x] == ) {
continue;
} else {
for(i = y; (i > ) && (a[i-][x] == ); i--) {
a[i-][x] = a[i][x];
a[i][x] = ;
move = ;
}
}
}
break;
case 'S':
case 's':
//从下向上消去相同方块
for(x = ; x < ; x++)
for(y = ; y >= ; ) {
if(a[y][x] == ) {
y--;
continue;
} else {
for(i = y - ; i >= ; i--) {
if(a[i][x] == ) {
continue;
} else if(a[y][x] == a[i][x]) {
a[y][x] += a[i][x];
a[i][x] = ;
y = i -;
empty++;
break;
} else {
y = i;
break;
}
}
y = i;
}
}
//向下移动方块
for(x = ; x < ; x++)
for(y = ; y >= ; y--) {
if(a[y][x] == ) {
continue;
} else {
for(i = y; (i < ) && (a[i+][x] == ); i++) {
a[i+][x] = a[i][x];
a[i][x] = ;
move = ;
}
}
}
break;
case 'Q':
case 'q':
game_over();
break;
default:
continue;
break;
} if(empty <= )
game_over();
draw();
//生成新方块
if((empty != old_empty) || (move == )) { //修复了不移动或消除方块也生成新方块的bug
do {
new_x = rand() % ;
new_y = rand() % ;
}while(a[new_y][new_x] != ); cnt_value(&new_y, &new_x); do {
tmp = rand() % ;
}while(tmp == || tmp == );
a[new_y][new_x] = tmp + ;
empty--; draw_one(new_y, new_x);
}
}
} int cnt_one(int y, int x)
{
int value = ; if(y - > )
a[y-][x] ? : value++;
if(y + < )
a[y+][x] ? : value++;
if(x - >= )
a[y][x-] ? : value++;
if(x + < )
a[y][x+] ? : value++;
if(y - >= && x - >= )
a[y-][x-] ? : value++;
if(y - >= && x + < )
a[y-][x+] ? : value++;
if(y + < && x - >= )
a[y+][x-] ? : value++;
if(y + < && x + < )
a[y+][x+] ? : value++; return value;
} void cnt_value(int *new_y, int *new_x)
{
int max_x, max_y, x, y, value;
int max = ; max = cnt_one(*new_y, *new_x);
for(y = ; y < ; y++)
for(x = ; x < ; x++) {
if(!a[y][x]) {
value = cnt_one(y, x);
if(value > max && old_y != y && old_x != x) { //避免在同一位置反复出现新方块
*new_y = y;
*new_x = x;
old_x = x;
old_y = y;
break;
}
}
}
} int game_over()
{
sleep();
endwin();
exit();
}

vim game_2048.c,按下i进入编辑模式,然后将上面的代码复制进去,再按Esc退出编辑模式,按下:x保存并退出。

然后在终端运行:gcc game_2048.c -o 2048 -lcurses 进行编译,最后输入./2048即可运行2048。方向键是wasd。

效果截图:

Linux下的C之2048的更多相关文章

  1. linux下安装apache与php;Apache+PHP+MySQL配置攻略

    1.apache   在如下页面下载apache的for Linux 的源码包    http://www.apache.org/dist/httpd/;   存至/home/xx目录,xx是自建文件 ...

  2. Linux下如何查看高CPU占用率线程

    转于:http://www.cnblogs.com/lidabo/p/4738113.html 目录(?)[-] proc文件系统 proccpuinfo文件 procstat文件 procpidst ...

  3. Linux下不同服务器间数据传输--转载

    因为工作原因,需要经常在不同的服务器见进行文件传输,特别是大文件的传输,因此对linux下不同服务器间数据传输命令和工具进行了研究和总结.主要是rcp,scp,rsync,ftp,sftp,lftp, ...

  4. Linux下不同服务器间数据传输

    因为工作原因,需要经常在不同的服务器见进行文件传输,特别是大文件的传输,因此对linux下不同服务器间数据传输命令和工具进行了研究和总结.主要是rcp,scp,rsync,ftp,sftp,lftp, ...

  5. Linux 下的dd命令使用详解(摘录)

    一.dd命令的解释 dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换. 注意:指定数字的地方若以下列字符结尾,则乘以相应的数字:b=512:c=1:k=1024:w=2 参数注释: 1. ...

  6. linux下不同服务器间数据传输(rcp,scp,rsync,ftp,sftp,lftp,wget,curl)(zz)

    linux下不同服务器间数据传输(rcp,scp,rsync,ftp,sftp,lftp,wget,curl) 分类: linux2011-10-10 13:21 8773人阅读 评论(1) 收藏 举 ...

  7. linux下多路复用模型之Select模型

    Linux关于并发网络分为Apache模型(Process per Connection (进程连接) ) 和TPC , 还有select模型,以及poll模型(一般是Epoll模型) Select模 ...

  8. Linux下java获取CPU、内存、磁盘IO、网络带宽使用率

    一.CPU 使用proc文件系统,"proc文件系统是一个伪文件系统,它只存在内存当中,而不占用外存空间.它以文件系统的方式为访问系统内核数据的操作提供接口.用户和应用程序可以通过proc得 ...

  9. linux下常用文件传输命令 (转)

    因为工作原因,需要经常在不同的服务器见进行文件传输,特别是大文件的传输,因此对linux下不同服务器间数据传输命令和工具进行了研究和总结.主要是rcp,scp,rsync,ftp,sftp,lftp, ...

随机推荐

  1. JavaMail入门第三篇 发送邮件

    JavaMail API中定义了一个java.mail.Transport类,它专门用于执行邮件发送任务,这个类的实例对象封装了某种邮件发送协议的底层实施细节,应用程序调用这个类中的方法就可以把Mes ...

  2. java四大域总结

    最近学完了web部分,发现有些地方总是单个容易理解,可是把所有的放在一起来大杂烩,总是有那么几个知识点容易混淆.其实网上的资料已经够多了,虽然也不乏辛劳的搬运工.可是最终的目的不就是要我们自身理解吗? ...

  3. FAQ_1_陌生的VERSION.SDK_INT

    看到VERSION.SDK_INT不禁诧异,这是何物?! 看API的定义,如下: 原来是一个常量值.但是这个常量值可以根据系统的不同而不同哟!为了揭开其神秘的面纱,将源码ctrl如下: 可以看出,获取 ...

  4. 来自亚马逊CEO Jeff Bezos的20句经验之谈

    英文原文:The 20 Smartest Things Jeff Bezos Has Ever Said 当外界对一个公司的热情有些偏离常态时, 就会出现武断的言论,亚马逊对此就深有感受.2000 年 ...

  5. A除以B问题

    描述:本题要求计算A/B,其中A是不超过1000位的正整数,B是1位正整数.你需要输出商数Q和余数R,使得A = B * Q + R成立. 输入:输入在1行中依次给出A和B,中间以1空格分隔. 输出: ...

  6. IOS 计步器

    这篇博客介绍的是当前比较流行的“计步器”-只是简单的知识点 计步器的实现在IOS8开始进行了改变. 但是我会对之前之后的都进行简单介绍. IOS 8 - // // ViewController.m ...

  7. unity下载文件二(http同步下载)

    说到下载,其实C#里的网络模块,真的是被各种封装,最终就看你对这个语言中库的熟悉程度了. 抛开C#中IO效率的弊病不说,真的很容易,记住,太过于注重效率或者追求极致,你将会死的很惨,有时候折中才是最好 ...

  8. NSDictionary和NSMutableDictionary

    #import <Foundation/Foundation.h> int main(int argc, const char * argv[]) { @autoreleasepool { ...

  9. iOS扫一扫功能开发

    之前很多二维码扫描都是基于zxing做的,但是zxing用起来真的很麻烦,又一直不更新.随着iOS6退出历史舞台,终于可以使用iOS7以后,用系统的AVFoundation做的二维码扫描器了. 初始化 ...

  10. 【文章内容来自《Android 应用程序开发权威指南》(第四版)】如何设计兼容的用户界面的一些建议(有删改)

    最近一直在看的一本书是<Android 应用程序开发权威指南>(第四版),十分推荐.书中讲到了一些用户界面设计的规范,对于初学者我认为十分有必要,在这里码给大家,希望对我们都有用. 在我们 ...