ncurses库安装命令

sudo apt-get install libncurses5-dev

2048游戏源码

#include <stdio.h>
#include <stdlib.h>
#include <curses.h>
#include <unistd.h>
#include <signal.h>
#include <time.h>int a[4][4] = {0};
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 0;
}void init()
{int x, y;initscr();cbreak();noecho();curs_set(0);empty = 15;srand(time(0));x = rand() % 4;y = rand() % 4;a[y][x] = 2;draw();
}void draw()
{int n, m, x, y;char c[4] = {'0', '0', '0', '0'};clear();for(n = 0; n < 9; n += 2)   //绘制横线,n代表行,m代表列{for(m = 0; m < 21; m++){move(n, m);addch('-');refresh();}}for(m = 0; m < 22; m += 5)  //绘制竖线{for(n = 1; n < 8; n++){move(n, m);addch('|');refresh();}}for(y = 0; y < 4; y++)     //绘制数字{for(x = 0; x < 4; x++){draw_one(y, x);}}
}void draw_one(int y, int x)
{int i, m, k, j;char c[5] = {0x00};i = a[y][x];m = 0;while(i > 0){j = i % 10;c[m++] = j + '0';i = i / 10;}m = 0;k = (x + 1) * 5 - 1;while(c[m] != 0x00){move(2*y+1, k);addch(c[m++]);k--;}
}void play()
{int x, y, i, new_x, new_y, temp;int old_empty, move;char ch;while(1){move = 0;old_empty = empty;ch = getch();switch(ch) {case 97:    //左移  acase 104:   // hcase 68:    // 左移方向键for(y = 0; y < 4; y++)for(x = 0; x < 4; ){if(a[y][x] == 0){x++;continue;}else{for(i = x + 1; i < 4; i++){if(a[y][i] == 0){continue;}else{if(a[y][x] == a[y][i]){a[y][x] += a[y][i];a[y][i] = 0;empty++;break;}else{break;}}}x = i;}}for(y = 0; y < 4; y++)for(x = 0; x < 4; x++){if(a[y][x] == 0){continue;}else{for(i = x; (i > 0) && (a[y][i-1] == 0); i--){a[y][i-1] = a[y][i];a[y][i] = 0;move = 1;}}}break;case 100:   //右移 dcase 108:   // lcase 67:    //右移方向键for(y = 0; y < 4; y++)for(x = 3; x >= 0; ){if(a[y][x] == 0){x--;continue;}else{for(i = x - 1; i >= 0; i--){if(a[y][i] == 0){continue;}else if(a[y][x] == a[y][i]){a[y][x] += a[y][i];a[y][i] = 0;empty++;break;}else{break;}}x = i;}}for(y = 0; y < 4; y++)for(x = 3; x >= 0; x--){if(a[y][x] == 0){continue;} else{for(i = x; (i < 3) && (a[y][i+1] == 0); i++){a[y][i+1] = a[y][i];a[y][i] = 0;move = 1;}}}break;case 119:   //上移 wcase 107:   //kcase 65:    //上移方向键for(x = 0; x < 4; x++)for(y = 0; y < 4; ){if(a[y][x] == 0){y++;continue;}else{for(i = y + 1; i < 4; i++){if(a[i][x] == 0){continue;}else if(a[y][x] == a[i][x]){a[y][x] += a[i][x];a[i][x] = 0;empty++;break;} else{break;}}y = i;}}for(x = 0; x < 4; x++)for(y = 0; y < 4; y++){if(a[y][x] == 0){continue;}else{for(i = y; (i > 0) && (a[i-1][x] == 0); i--){a[i-1][x] = a[i][x];a[i][x] = 0;move = 1;}}}break;case 115:   //下移 scase 106:   //jcase 66:    //下移方向键for(x = 0; x < 4; x++)for(y = 3; y >= 0; ){if(a[y][x] == 0){y--;continue;}else{for(i = y - 1; i >= 0; i--){if(a[i][x] == 0){continue;}else if(a[y][x] == a[i][x]){a[y][x] += a[i][x];a[i][x] = 0;empty++;break;}else{break;}}y = i;}}for(x = 0; x < 4; x++)for(y = 3; y >= 0; y--){if(a[y][x] == 0){continue;}else{for(i = y; (i < 3) && (a[i+1][x] == 0); i++){a[i+1][x] = a[i][x];a[i][x] = 0;move = 1;}}}break;case 'Q':case 'q':game_over();break;default:continue;break;}if(empty <= 0)game_over();if((empty != old_empty) || (move == 1)){do{new_x = rand() % 4;new_y = rand() % 4;}while(a[new_y][new_x] != 0);cnt_value(&new_y, &new_x);do {temp = rand() % 4;}while(temp == 0 || temp == 2);a[new_y][new_x] = temp + 1;empty--;}draw();}
}int cnt_one(int y, int x)
{int value = 0;if(y - 1 > 0)a[y-1][x] ? 0 : value++;if(y + 1 < 4)a[y+1][x] ? 0 : value++;if(x - 1 >= 0)a[y][x-1] ? 0 : value++;if(x + 1 < 4)a[y][x+1] ? 0 : value++;if(y - 1 >= 0 && x - 1 >= 0)a[y-1][x-1] ? 0 : value++;if(y - 1 >= 0 && x + 1 < 4)a[y-1][x+1] ? 0 : value++;if(y + 1 < 4 && x - 1 >= 0)a[y+1][x-1] ? 0 : value++;if(y + 1 < 4 && x + 1 < 4)a[y+1][x+1] ? 0 : value++;return value;
}void cnt_value(int *new_y, int *new_x)
{int max_x, max_y, x, y, value;int max = 0;max = cnt_one(*new_y, *new_x);for(y = 0; y < 4; y++)for(x = 0; x < 4; x++){// 如果(y, 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(1);endwin();exit(0);
}

编译

(此处文件名为game_2048.c , 同理可做相应替换)

gcc game_2048.c -o 2048 -lcurses

运行

./2048

2048C语言源码linux相关推荐

  1. Go语言源码分析CAS的实现和Java如出一辙

    看了Go的源码CAS这块实现和java还是类似的. 关于Java的分析参考:Java使用字节码和汇编语言同步分析volatile,synchronized的底层实现 都是使用汇编指令:LOCK+CMP ...

  2. golang中文文档_【译】Go 语言源码贡献官方指导文档

    以前给 Go 语言项目源码提交过一些 commits,期间阅读他们的官方指导文档的时候觉得这篇指导文档可以作为绝佳的关于大型软件项目的规范管理的参考,因为最近又提交了几个 commits,就又把这篇文 ...

  3. 易语言php支付宝,支付宝填表登录易语言源码

    支付宝填表登录易语言源码 @MS_晨星天宇.版本 2 .支持库 spec .支持库 HtmlView .程序集 窗口程序集_窗口1 .子程序 _按钮1_被单击 调试输出 (开始登录 (超文本浏览框1, ...

  4. 技术宅的乐趣!网友编写出《流浪地球》“春节十二响”C语言源码

    [TechWeb]随着春节档科幻电影<流浪地球>的火爆,越来越多的网友对这部电影产生了浓厚的兴趣.电影中"春节十二响"的桥段相信会让每一个看过电影的观众记忆犹新. 近日 ...

  5. m3u8切片程序PHP视频切片软件转码系统易语言源码 云转码工具源码

    前端为易语言源码(含模块),后端为php源码[代码全开源 无加密]方便各种二开! 1.切片自动上传至你的服务器(m3u8链接) 2.切片完成后提示音 3.切片完成后(在软件上会自动显示地址) 4.批量 ...

  6. 易语言源码 VX多开 思路+源码

    介绍: 易语言源码 VX多开 思路+源码 网盘下载地址: http://kekewangLuo.cc/aOqsvkyTX0g 图片:

  7. C51单片机与PCF8591模块的交互:C语言源码解析

    目录 1. PCF8591模块简介 2. C51单片机与PCF8591的连接 3. C51单片机与PCF8591的C语言源码解析 4. 用法示例 5. 总结 6. 参考文献 在微控制器的世界中,C51 ...

  8. 【安全算法之SHA1】SHA1摘要运算的C语言源码实现

    [安全算法之SHA1]SHA1摘要运算的C语言源码实现 概述 头文件定义 C语言版本的实现源码 测试用例 github仓库 更多参考链接 概述 大家都知道摘要算法在安全领域,也是一个特别重要的存在,而 ...

  9. C语言项目源码,C语言源码大全

    一.C语言源码大全 C语言是一门通用计算机编程语言,广泛应用于底层开发.C语言的设计目标是提供一种能以简易的方式编译.处理低级存储器.产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言.尽管 ...

  10. E易语言源码图标修复

    易语言源码图标修复.zip-其它文档类资源-CSDN下载此软件用于修复Easy语言软件源代码图标不是默认的蓝色图标,还可以修复易语言文件关联(Win10已经更多下载资源.学习资料请访问CSDN下载频道 ...

最新文章

  1. 束文圣和黄立南Nature综述极端环境中的微生物多样性
  2. android getevent参数,android getevent、sendevent、input keyevent 使用说明
  3. C# SQLite 数据库操作语句与文件视图管理器
  4. 基于visual Studio2013解决C语言竞赛题之0304整除数
  5. 临颖一高2021高考成绩查询,临颍一高举办2021年决战高考百日冲刺誓师大会
  6. Android学习之路五:Dialog和Toast
  7. Linux 性能测试工具 sysbench 的安装与简单使用
  8. mac Sourcetree 账号密码输入错误后, 重新输入的方法
  9. Spring @Aspect注解
  10. 如何让自己成为优秀员工?
  11. 计算机中临时存储数据指令的部件,第一单元 探索计算机的奥秘
  12. redis for lack of backlog
  13. Linux内核4.14版本:ARM64的内核启动过程(一)——start_kernel之前
  14. loadrunner在win7破解提示:Cannot save the license information because acceses to the registry is denied的解
  15. C# 语言和 .NET Framework 介绍
  16. 企业邮箱注册申请,如何注册电子邮箱域名
  17. HTML5 网页添加背景音乐
  18. Mybatis学习笔记5——多对一处理、一对多处理
  19. 求和计算机教案,小学信息技术《自动求和》教案
  20. 二叉树的前、中、后序遍历

热门文章

  1. 造轮子之 npm i -g creatshare-app-init 源码浅析
  2. WordPress 前端投稿/编辑插件 DJD Site Post(支持游客和已注册用户)
  3. 浅谈PHP如何实现网站文章或博客浏览量页面访问量+1
  4. 安全好用的智能头盔,自带灯光提示与语音功能,力沃BH51M Neo体验
  5. 详解 Flink Metrics 原理与监控实战
  6. 联想笔记本小新air14,Fn+功能键/Insert键
  7. kinit 某个账户,提示 Clients credentials have been revoked
  8. 鸽哒im即时通讯源码
  9. 【JavaScript算法】---插入排序(转载自我的老师 Alley-巷子)
  10. RTB广告技术修炼之-流量漫游