#include "stdafx.h"

#include "stdlib.h"

#include "conio.h" //writeKey()按键函数

#include "time.h" //srand(time(0))随机数种子

int i, j, k,t,x,y; //定义的全局变量

int space; //空格数,根据空格数来判断游戏是否结束

int temp[4]; //将移动后的数字放在 temp[4] 中,再传递给arr[4]

int arr[4][4], copy[4][4]; //copy数组用于判断一次操作后arr数组是否发生变化

int flog = 0; //判断是否需要增加数字

//打印数字及界面

void show()

{

printf( "—————————————\n" );

for (i = 0; i < 4; i++)

{

for (j = 0; j < 4; j++)

{

if (arr[i][j] == 0)

{

printf("| 0"); //如果arr[i][j]没有数字 则打印0

}

else

{

printf("|%5d", arr[i][j]); //如果arr[i][j]有数字 则打印数字

}

}

printf("|\n—————————————\n");

}

}

//开始出现第一个随机数

void inter()

{

srand(time(0));

int x = rand() % 4; //随机数对4取余, 即x在4以内取值,

int y = rand() % 4; //随机数对4取余, 即y在4以内取值,

for (i = 0; i < 4; i++)

{

for (j = 0; j < 4; j++)

{

copy[i][j] = arr[i][j] = 0; //先将数组全部置为0

}

}

copy[x][y] = arr[x][y] = 2; //在随机的地方出现第一个数字2

space = 15; //空格数为15,根据空格数来判断游戏是否结束

}

//接受按键

int writeKey()

{

if (_kbhit()) //判断是否有按键

{ //

return _getch(); //如果有则返回按键

} //

return 0; //没有则返回0

}

//上移

void up()

{

for (i = 0; i < 4; i++) //先从第0列开始判断

{

for (j = 0; j < 4; j++) //第i列第一个开始判断

{

if (arr[j][i] == 0) continue; //为0 则跳过

else

{

for (k = j + 1; k < 4; k++) //第i列第2个开始判断,从上往下依次判断

{

if (arr[k][i] == 0) continue; //为0 则跳过

if (arr[k][i] == arr[j][i]) //相等则可以相加

{

arr[j][i] *= 2; //相同数字相加即*2

arr[k][i] = 0; //相加后因为上移将下方的数字归0

space++; //数字少了则空格多一

k = j = 0; //再从头开始判断是否有相同数字

break;

}

else break;

}

}

} //第i列全部相加完成后,

t = 0; //使temp数组从0开始

for (j = 0; j < 4; j++) //遍历第i列

{ //

if (arr[j][i] != 0) //不为0

{ //

temp[t++] = arr[j][i]; //上移后,有数字则数字永远在上面,

arr[j][i] = 0; //使 不会影响temp数组

} //

} //

while (t < 4) //判断数组是否满了

{ //

temp[t++] = 0; //将数组剩余元素全部置0

} //

for (j = 0; j < 4; j++) //遍历第i列

{ //

arr[j][i] = temp[j]; //将temp数组的值传递给第i列

}

}

}

//下移

void down()

{

for (i = 0; i < 4; i++) //先从第0列开始判断

{

for (j = 3; j >= 0; j--) //第i列倒数第一个开始判断,下移所有数字都在下面

{

if (arr[j][i] == 0) continue; //为0 则跳过

else

{

for (k = j - 1; k >= 0; k--) //第i列倒数第2个开始判断,从下往上依次判断

{

if (arr[k][i] == 0) continue; //为0 则跳过

if (arr[k][i] == arr[j][i]) //相等则可以相加

{

arr[j][i] *= 2; //相同数字相加即*2

arr[k][i] = 0; //相加后因为下移将上方的数字归0

space++; //数字少了则空格多一

k = j = 3; //再从头开始判断是否有相同数字

break;

}

else break;

}

}

} //第i列全部相加完成后,

t = 0; //使temp数组从0开始

for (j = 3; j >= 0; j--) //遍历第i列

{ //

if (arr[j][i] != 0) //不为0

{ //

temp[t++] = arr[j][i]; //下移后,有数字则数字永远在下面,

arr[j][i] = 0; //使 不会影响temp数组

} //

} //

while (t < 4) //判断数组是否满了

{ //

temp[t++] = 0; //将数组剩余元素全部置0

} //

t = 0; //将t置0

for (j = 3; j >= 0; j--) //遍历第i列

{ //

arr[j][i] = temp[t++]; //将temp数组的值传递给第i列

}

}

}

//左移

void lift()

{

for (i = 0; i < 4; i++) //先从第0行开始判断

{

for (j = 0; j < 4; j++) //第i行从左往右第一个开始判断

{

if (arr[i][j] == 0) continue; //为0 则跳过

else

{

for (k = j + 1; k < 4; k++) //第i行第2个开始判断,从左往右依次判断

{

if (arr[i][k] == 0) continue; //为0 则跳过

else //相等则可以相加

{

if (arr[i][k] == arr[i][j])

{

arr[i][j] *= 2; //相同数字相加即*2

arr[i][k] = 0; //相加后因为左移将右边的数字归0

space++; //数字少了则空格多一

k = j = 0; //再从头开始判断是否有相同数字

break;

}

else break;

}

}

}

} //第i行全部相加完成后,

t = 0; //使temp数组从0开始

for (j = 0; j < 4; j++) //遍历第i行

{ //

if (arr[i][j] != 0) //不为0

{ //

temp[t++] = arr[i][j]; //左移后,有数字则数字永远在左

arr[i][j] = 0; //使 不会影响temp数组

} //

} //

while (t < 4) //判断数组是否满了

{ //

temp[t++] = 0; //将数组剩余元素全部置0

} //

for (j = 0; j < 4; j++) //遍历第i行

{ //

arr[i][j] = temp[j]; //将temp数组的值传递给第i行

}

}

}

//右移

void right()

{

for (i = 0; i < 4; i++) //先从第0行开始判断

{

for (j = 3; j >= 0; j--) //第i行从左往右倒数第一个开始判断

{

if (arr[i][j] == 0) continue; //为0 则跳过

else

{

for (k = j - 1; k >= 0; k--) //第i行倒数第2个开始判断,从右往左依次判断

{

if (arr[i][k] == 0) continue; //为0 则跳过

else //相等则可以相加

{

if (arr[i][k] == arr[i][j])

{

arr[i][j] *= 2; //相同数字相加即*2

arr[i][k] = 0; //相加后因为右移将左边的数字归0

space++; //数字少了则空格多一

k = j = 3; //再从头开始判断是否有相同数字

break;

}

else break;

}

}

}

} //第i行全部相加完成后,

t = 0; //使temp数组从0开始

for (j = 3; j >= 0; j--) //遍历第i行

{ //

if (arr[i][j] != 0) //不为0

{ //

temp[t++] = arr[i][j]; //右移后,有数字则数字永远在右边

arr[i][j] = 0; //使 不会影响temp数组

} //

} //

while (t < 4) //判断数组是否满了

{ //

temp[t++] = 0; //将数组剩余元素全部置0

} //

t = 0; //

for (j = 3; j >= 0; j--) //遍历第i行

{ //

arr[i][j] = temp[t++]; //将temp数组的值传递给第i行

}

}

}

//增加数字

void add()

{

for (i = 0; i < 4; i++) //遍历数组

{ //

for (j = 0; j < 4; j++) //

{ //

if (arr[i][j] != copy[i][j]) //两个数组不同则需要增加数字

{ //

flog = 1; //中间媒介

copy[i][j] = arr[i][j]; //令两个数组相同,不会再有麻烦

}

}

}

if (flog == 1) //需要增加数字

{

system("cls"); //清屏

do //只有当arr[x][y]在arr数组中的 0 位时,才出现

{ //

x = rand() % 4; //随机数对4取余, 即x在4以内取值,

y = rand() % 4; //随机数对4取余, 即y在4以内取值,

} while (arr[x][y] != 0); //

copy[x][y] = arr[x][y] = (rand() & 0x1 ? 2 : 4); //随机数与1(00000001)按位与,即随机数个位前全部取0,个位取0或1,再进行三目运算符,随机取2或4

space--; //增加数字则空格减一

flog = 0; //防止数组没有发生变化也一直增加数字

show(); //打印数字及界面

}

}

//判断按键方向

void dir()

{

int oper = writeKey(); //调用writeKey()函数

switch (oper) //

{ //

case 'W': //按下W

up(); break; //上移

case 'S': //按下S

down(); break; //下移

case 'A': //按下A

lift(); break; //左移

case 'D': //按下D

right(); break; //右移

default: break;

}

}

//封装函数

void play()

{

inter(); //开始出现第一个随机数

show(); //打印数字及界面

while (space) //根据空格数来判断游戏是否结束

{ //

dir(); //判断按键方向

add(); //增加数字

}

}

int _tmain(int argc, _TCHAR* argv[])

{

play(); //封装函数

printf("垃圾");

system("pause"); //

return 0; //

}

2048c语言的思路,C语言版2048小游戏创作思路及代码相关推荐

  1. C语言版2048小游戏创作思路及代码

    自己学习c语言也有一段时间,但还是对c语言没有感觉,所有想通过写博客来提高自己对c语言的理解. 在写2048的时候,参考了不少优秀的代码,也有一些自己的理解,希望能给大家一些参考. 先要有界面,顺带把 ...

  2. 2048网页版html项目报告,jQuery编写网页版2048小游戏

    大致介绍 看了一个实现网页版2048小游戏的视频,觉得能做出自己以前喜欢玩的小游戏很有意思便自己动手试了试,真正的验证了这句话-不要以为你以为的就是你以为的,看视频时觉得看懂了,会写了,但是自己实现起 ...

  3. java编辑2048小游戏_Java 制作命令行版 2048小游戏

    Java 命令行版 2048小游戏(2020年8月14日) 制作背景 大二即将开学,从头开始学习了一个多月的java,对二维数组的操作稍微熟悉了一些.于是想做一个简单的2048来试一试. 众所周知,2 ...

  4. 网页版2048小游戏

    网页版2048小游戏 使用jquery3.3.1 进行的一次开发,各文件源码如下: 2048.css .div_2048{background-color: #FFFAF0;width:1000px; ...

  5. go语言实现2048小游戏(完整代码)

    文章目录 2048逻辑分析 完整代码 2048逻辑分析 2048小游戏的基本操作是上下左右,每个操作的逻辑都不太一样! 这个时候,通过数组旋转的方式.将所有操作转换为向上的操作 git地址 https ...

  6. C语言在linux终端下实现2048小游戏:第二版

    原来我转载过一个机遇ncurses的2048,今天无聊自己手写了一个,看下我的目录结构: $ tree ../2048/ ../2048/ ├── 2048.c ├── 2048.h └── main ...

  7. C++ 控制台版 2048小游戏

    先说说2048游戏的规则: 开始的时候空格中会出现两个数字(只能为2或者4),用户可以选择上下左右键进行移动,数字们整体沿着方向移动,中间不存在空格,如果相邻的两个数字相等,那么合并至沿着方向的后一个 ...

  8. html css js实现快递单打印_JS与HTML、CSS实现2048小游戏(六)

    在前面的五篇文章中,小编带大家完成了网页版2048小游戏的基本游戏逻辑.但是在游戏结束的gameover()方法中咱们只是简单的通过alert来弹出一些信息,这样的话只能出现下图的效果.这样的游戏,不 ...

  9. java编写2048小游戏

    java版2048小游戏 java编写2048小游戏 java编写2048小游戏 // An highlighted block /*** */ package games;/*** @author ...

最新文章

  1. Shell命令-文件及内容处理之more、less
  2. leetcode算法第9题
  3. 怎样用python自动化办公_会python基础,如何学习自动化办公?
  4. PHP学习2——基本语法
  5. std::ostream_iterator、std::cout、std:copy实现输出
  6. Facebook 如何管理150亿张照片
  7. 微分方程在matlab中的实现,Matlab微分方程参数优化的Forcal实现
  8. 133_Power BI 报表服务器2020年1月版本更新亮点
  9. 【日本語勉強】日本語四級文法突撃(11~20)
  10. 决策树算法python源代码_CART决策树(Decision Tree)的Python源码实现
  11. 15分钟破解保险箱!美国小哥200美元自制开锁机器人
  12. 大数据分析方法有哪几种?
  13. 2021-07-112021年中式烹调师(初级)模拟考试题及中式烹调师(初级)实操考试视频
  14. HarmonyOS应用开发 — HelloWorld应用开发E2E体验
  15. 图像低频、高频信息的理解
  16. word文字 分列插入execl
  17. dcc-garch matlab,如何用Eviews或者MATLAB实现DCC-garch模型?
  18. 马尔奖得主 Alan Yuille | AI 视觉的未来:像人一样看世界
  19. 使用Fiddler实现网络限速
  20. 文档空白页删除办法-从空白页出现的原因解决

热门文章

  1. 3D 激光雷达传感器提供远程移动监控
  2. 为什么大明王朝会灭亡?
  3. python的三种打开方式,怎么用python打开软件
  4. SOLIDWORKS凸轮和铰链等机械结构怎么配合?
  5. 梦幻西游的服务器能修改吗,注意事项,不是所有服务器都可以免费改名的
  6. 1.Python教程--基础篇(全)
  7. 大疆精灵4多光谱辐射信息分析
  8. 【干货】企业邮箱被列入黑名单如何解除,已解决!
  9. 使用ImageJ批量处理图像 超好用持续更新常用操作
  10. 阿里旺旺发送文件以保存服务器,使用阿里旺旺收发文件