




免费预览已结束,剩余4页可下载查看
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include#include /使用getch()函数 #include #include int num44;int score, gameover, ifappear, gamew, gamef,move;char key;void explation() void menu(); system(cls); printf(tt*ttn); printf(tt*n); printf(tt*游戏规则*n); printf(tt*n); printf(tt*ttn); printf(玩家可以选择上、下、左、右或W、A、S、D去移动滑块n); printf(玩家选择的方向上若有相同的数字则合并n); printf(合并所得的所有新生成数字相加即为该步的有效得分n); printf(玩家选择的方向行或列前方有空格则出现位移n); printf(每移动一步,空位随机出现一个2或4n); printf(棋盘被数字填满,无法进行有效移动,判负,游戏结束n); printf(棋盘上出现2048,获胜,游戏结束n); printf(按上下左右去移动滑块n); printf(请按任意键返回主菜单.n); getch(); system(cls); main();void gamefaile() int i, j; system(cls); printf(tt*ttn); printf(tt*n); printf(tt*you fail*n); printf(tt*n); printf(tt*ttn); printf(ttt-nttt); for (j = 0; j4; j+) for (i = 0; i4; i+) if (numji = 0) printf(| ); else printf(|%4d, numji); printf(|n); printf(ttt-nttt); printf(你的成绩:%d,移动了%d步n, score,move); printf(请按任意键返回主菜单.n); getch(); system(cls); main(); void gamewin() int i, j; system(cls); printf(tt*ttn); printf(tt*n); printf(tt*you win*n); printf(tt*n); printf(tt*ttn); printf(ttt-nttt); for (j = 0; j4; j+) for (i = 0; i4; i+) if (numji = 0) printf(| ); else printf(|%4d, numji); printf(|n); printf(ttt-nttt); printf(你的成绩:%d,移动了%d步n, score,move); printf(请按任意键返回主菜单.n); getch(); system(cls); main();void prin() int i, j; system(cls); printf(tt*ttn);/输出界面 printf(tt*n); printf(tt*游戏开始*n); printf(tt*n); printf(tt*ttn); printf(tt 请按方向键或W、A、S、D移动滑块n);/输出操作提示语句 printf(tt 按ESC返回至主菜单n); printf(ttt-nttt); for (j = 0; j4; j+) /输出4*4的表格 for (i = 0; i4; i+) if (numji = 0) printf(| ); else printf(|%4d, numji); printf(|n); printf(ttt-nttt); printf(你的成绩:%d,移动了%d步n, score,move);/输出得分和移动步数void appear() int i, j,ran,t16,x=0,a,b; srand(int)time(0); /随机种子初始化 for (j = 0; j 4; j+) /将空白的区域的坐标保存到中间数组t中 for (i = 0; i 2) /在此空白区域随机赋值2或4 numab = 2; else numab = 4;void close() exit(0);void add(int *p) int i=0, b; while (i3) if (*(p + i) != 0) for (b = i + 1; b 4; b+) if (*(p + b) != 0) if (*(p + i) = *(p + b) score = score + (*(p + i) + (*(p + b); *(p + i) = *(p + i) + *(p + b); if (*(p + i) = 2048) gamew = 1; *(p + b) = 0; i = b + i; +ifappear; break; else i = b; break; if (b = 4) i+; else i+; void Gameplay() int i, j, g, e, a, b4; appear(); appear(); while (1) if (ifappear!=0) appear(); prin(); key = getch(); switch (key) case w: case W: case 72: ifappear = 0; for (j = 0; j 4; j+) for (i = 0; i 4; i+) bi = numij; numij = 0; add(b); e = 0; for (g = 0; g 4; g+) if (bg != 0) numej = bg; if (g != e) +ifappear; e+; if (ifappear!=0) +move; break; case s: case S: case 80: ifappear = 0; for (j = 0; j 4; j+) for (i = 0; i =0; g-) if (bg != 0) numej = bg; if (g != e) +ifappear; e-; if (ifappear != 0) +move; break; case a: case A: case 75: ifappear = 0; for (j = 0; j 4; j+) for (i = 0; i 4; i+) bi = numji; numji = 0; add(b); e = 0; for (g = 0; g 4; g+) if (bg != 0) numje = bg; if (g!=e) +ifappear; e+; if (ifappear != 0) +move; break; case d: case D: case 77: ifappear = 0; for (j = 0; j 4; j+) for (i = 0; i =0; g-) if (bg != 0) numje = bg; if (g!=e) +ifappear; e-; if (ifappear != 0) +move; break; case 27: system(cls); main(); break; for (j = 0; j 4; j+) for (i = 0; i 4; i+) if (j 3) if (i 3) if (numji = numj + 1i | numji = numji + 1 | numji = 0) gamef = 0; break; else gamef = 1; else if (numji = numj + 1i | numji = 0) gamef = 0; break; else gamef = 1; else if (i 3) if (numji = numji + 1 | numji = 0 | numji + 1 = 0) gamef = 0; break; else gamef = 1; if (gamef = 0) break; if (gamef = 1 | gamew = 1) break; if (gamef = 1) gamefaile(); else gamewin();void menu() int n; printf(tt*ttn); /输出游戏菜单的图形 printf(tt* 1、开始游戏 *n); printf(tt* 2、游戏规则 *n); printf(tt* 3、退出游戏 *n); printf(tt*n); printf(请输入1或2或3: bb); scanf(%d, &n); switch (n) case 1: Gameplay(); /游戏开始函数 break; case 2: explation(); /游戏规则函数 break; case 3: close(); /关闭游戏函数 break; int main() int j, i; for (j = 0; j 4; j+) /对4*4进行初始赋值为0 for (i = 0; i
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 外墙防水保修合同书
- 时间主题的课件
- 企业信用评级与授信咨询服务协议
- 产品推广代理合同协议
- 过春节的活动作文(8篇)
- 早期教育概论课件
- 《新编商务应用文写作》第一章 习题参考答案
- 水孩子读后感250字(9篇)
- 早教分离焦虑课件
- 2025年瑞典语等级考试B1试卷:2025秋季学期词汇拓展
- 影像科品管圈QCC成果报告 缩短影像报告等待时间护理课件
- 《原生动物》课件
- 结构施工图审图要点
- 医务人员人文素养提升系列讲座
- 异常行为与动物保护
- 危险化学品的安全储存和使用
- 精神障碍社区康复服务 基本情况登记表(模板)、精神障碍社区康复服务协议(模板)
- JCT2415-2017 用于陶瓷砖粘结层下的防水涂膜
- 2023施工技术交底编制与管理标准培训
- 物业管理考核细则-
- GB/T 3683-2023橡胶软管及软管组合件油基或水基流体适用的钢丝编织增强液压型规范
评论
0/150
提交评论