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

  1. 先要有界面,顺带把数字放进去
//打印数字及界面
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");}
}

2.要有随机数,并且随机数不能出现在非0位上

//开始出现第一个随机数
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;        //在随机的地方出现第一个数字2space = 15;                       //空格数为15,根据空格数来判断游戏是否结束
}

3.接受按键

//接受按键
int writeKey()
{if (_kbhit())                    //判断是否有按键{                                //return _getch();             //如果有则返回按键}                                //return 0;                        //没有则返回0
}

4.上下左右移动
上下则 从列判断, 左右则从行判断
思路为 一列或一行的判断是否数字相同,相同则相加,不同则跳过,遍历完列或行后,将移动后arr的数字传递给temp,要从非0数开始传递,再将temp传递给arr。
5.如何将出现移动后的数字
需另一数组保存原来列或行的数字,即temp数组
6.判断是否需要增加数字
需另一数组copy数组,(注意==与=的区别)

基本思路就是这样,下面是全部的代码及注释


#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;        //在随机的地方出现第一个数字2space = 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;                  //相同数字相加即*2arr[k][i] = 0;                  //相加后因为上移将下方的数字归0space++;                        //数字少了则空格多一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;                    //相同数字相加即*2arr[k][i] = 0;                  //相加后因为下移将上方的数字归0space++;                        //数字少了则空格多一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置0for (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;                     //相同数字相加即*2arr[i][k] = 0;                      //相加后因为左移将右边的数字归0space++;                            //数字少了则空格多一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;                 //相同数字相加即*2arr[i][k] = 0;                  //相加后因为右移将左边的数字归0space++;                        //数字少了则空格多一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或4space--;                                            //增加数字则空格减一flog = 0;                                           //防止数组没有发生变化也一直增加数字show();                                             //打印数字及界面}
}//判断按键方向
void dir()
{int oper = writeKey();         //调用writeKey()函数switch (oper)                  //{                              //case 'W':                      //按下W up();    break;            //上移case 'S':                      //按下S down();  break;            //下移case 'A':                      //按下Alift();  break;            //左移case 'D':                      //按下Dright(); break;            //右移default: break;}
}//封装函数
void play()
{                                     inter();                          //开始出现第一个随机数show();                           //打印数字及界面while (space)                     //根据空格数来判断游戏是否结束{                                 //dir();                        //判断按键方向add();                        //增加数字}
}int _tmain(int argc, _TCHAR* argv[])
{play();                            //封装函数printf("垃圾");                    system("pause");                   //return 0;                          //
}

希望可以给大家一些帮助,也是自己make一下,怕自己记性不好给忘了。

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

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

    #include "stdafx.h" #include "stdlib.h" #include "conio.h" //writeKey( ...

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

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

  3. C语言实现2048小游戏---粤嵌GE6818嵌入式系统实训

    C语言实现2048小游戏---粤嵌GE6818嵌入式系统实训 实现的全部功能: 功能演示: 版本介绍 简易版--大佬选这个 完整版--想保研.想得高分.想要装逼的同学选这个 至尊版--零基础的.想要装 ...

  4. C语言编写2048小游戏

    该博文为原创文章,未经博主同意不得转载,如同意转载请注明博文出处 本文章博客地址:https://cplusplus.blog.csdn.net/article/details/104992424 2 ...

  5. C语言实现2048小游戏

    C语言实现2048小游戏-粤嵌GE6818嵌入式系统实训 部分功能演示视频. 实现的全部功能: 1.字模显示封面组员名字 2.完成2048游戏在板子上的运行 3.成功或者失败需要有标志也可以计分 4. ...

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

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

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

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

  8. java 2048游戏_JAVA2048游戏 本课程设计是基于java语言的2048小游戏设计 联合开发网 - pudn.com...

    JAVA2048游戏 所属分类:游戏 开发工具:Java 文件大小:789KB 下载次数:4 上传日期:2020-11-23 10:57:11 上 传 者:滴滴滴大萌 说明:  本课程设计是基于jav ...

  9. 网页版2048小游戏

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

最新文章

  1. 2022-2028年中国橡胶带行业市场运营格局及未来前景分析报告
  2. 模板方法设计模式与策略模式
  3. android 中 webview 怎么用 localStorage?
  4. Java——递归练习
  5. mysql error report,ECSHOP网店系统提示MYSQL SERVER ERROR REPORT的解决方法
  6. 编程的心法与注意事项
  7. css3 rem的用法
  8. 深度学习文献阅读笔记(6)
  9. Symbian s40 Java编程实战(一)--开发环境配置
  10. 智道分析吊瓜子的营养价值
  11. 小数处理函数(trun(),round(),ceil()和floor())
  12. 获取子进程终止状态:wait和waitpid
  13. 如何确定产品生命周期
  14. 原函数与导函数的关系,以及驻点处二阶导函数大于、小于、等于零时,原函数取极小值、极大值或鞍点的情况。
  15. 五种常见的加密方式及常用的加解密工具
  16. window10目前(2021.2.13)的iTunes的iOS更新升级固件位置
  17. 雷军:穿越人生低谷的感悟(节选)
  18. 绿幕背景抠图,去除掉物体周围一圈的绿边 OpenCVForUnity
  19. tomcat使用cronolog进行日志切割
  20. nodejs京东接口分析系列-实现京东自动化功能 之 扫码登陆,需要puppeteer

热门文章

  1. 授予人工智能计算中心解决方案的智博会金奖,对AI意味着什么?
  2. 对智博教育的midia-class(奥义多媒体教室)(0ss-midia-class)的破解①(共两部分)
  3. 算法模型是什么意思,算法模型定义介绍
  4. 大陆身份证校验——Oracle版本
  5. php如何开发调色器,PHP imagecreate - 新建一个基于调色板的图像
  6. 2021年电工(中级)免费试题及电工(中级)模拟考试题库
  7. 安装MinGW win安装gcc
  8. excel熵值法计算权重_指标权重确定方法 1-熵值法
  9. LaTeX 图片和公式引用
  10. XX项目的现状与对策