本文实例为大家分享了C语言实现消消乐游戏的具体代码,供大家参考,具体内容如下

问题描述

给定一个矩阵, 判断移动哪一个格子,可以实现消除。(定义连续三个即可消除)

据说是华为的笔试题。

分析

先写一个函数,判断包含(i, j)的格子是否可能实现消除。

然后就是向右向下交换,然后调用上面写好的函数判断

被交换的两个格子是否实现消除。

重点是:

1、只需要向右向下交换,因为遍历的时候,后面的交换会重复。前一个判断了向右交换是否消除,后一个遍历就不需要再判断向左交换是否重复了。

2、一定要对被交换的两个格子都判断是否能消除,才能实现全面的判断。

代码

//

// main.cpp

// huawei

//

// Created by SteveWong on 11/10/2016.

// Copyright © 2016 SteveWong. All rights reserved.

//

#include

#include

#include

#include

//#include

using namespace std;

const int LEN = 8;

void pmap(int map[][LEN])

{

for (int i = 0; i < LEN; ++i)

{

for (int j = 0; j < LEN; ++j)

{

cout << map[i][j] << " ";

}

cout << endl;

}

}

// 检查以(i,j)为中心的点, 看是否可以消除

bool check(int map[][LEN], int i, int j)// 保证i、j不越界,

{

if (

(i-1>=0 && i+1

|| (j-1>=0 && j+1

|| (i-2>=0 && map[i-2][j]==map[i-1][j]&&map[i-1][j]==map[i][j])

|| (j-2>=0 && map[i][j-2]==map[i][j-1]&&map[i][j-1]==map[i][j])

|| (i+2

|| (j+2

)

{

return true;

}

return false;

}

bool swapAndJudge(int m[][LEN], int i, int j)// 保证i、j不越界, 应该对被swap的两个点都做纵向和横向的检查

{

int map[LEN][LEN];

for (int ii = 0; ii < LEN; ++ii)

{

for (int jj = 0; jj < LEN; ++jj)

{

map[ii][jj] = m[ii][jj];

}

}

// 原来就可以消除

if (check(map, i, j))

{

printf("no need to swap at (%d, %d)\n", i, j);

return true;

}

// 只需要向下换和向右换

// 向下换

if (i + 1 < LEN)

{

swap(map[i+1][j], map[i][j]);

if (check(map, i, j))

{

printf("# swap and sweap! (%d, %d)\n", i, j);

return true;

}

if (check(map, i+1, j))

{

printf("# swap and sweap! (%d, %d)\n", i+1, j);

return true;

}

swap(map[i+1][j], map[i][j]);// 换回来

}

// 向右换

if (j + 1 < LEN)

{

swap(map[i][j+1], map[i][j]);

if (check(map, i, j))

{

printf("# swap and sweap! (%d, %d)\n", i, j);

return true;

}

if (check(map, i, j+1))

{

printf("# swap and sweap! (%d, %d)\n", i, j+1);

return true;

}

swap(map[i][j+1], map[i][j]);// 换回来

}

return false;

}

void findMinSwap(int map[][LEN])

{

for (int i = 0; i < LEN; ++i)

{

for (int j = 0; j < LEN; ++j)

{

if (swapAndJudge(map, i, j))

{

printf("gotcha! (%d, %d)\n", i, j);

}

}

}

}

int main(int argc, const char * argv[]) {

// insert code here...

// std::cout << "Hello, World!\n";

srand(unsigned(time(0)));

for (int i = 0; i < LEN; ++i)

{

for (int j = 0; j < LEN; ++j)

{

map[i][j] = rand() % 5;

}

}

cout << "xiaoxiaole!\n";

findMinSwap(map);

pmap(map);

return 0;

}

更多有趣的经典小游戏实现专题,分享给大家:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

python实现消消乐游戏_C语言实现消消乐游戏相关推荐

  1. python编写格斗游戏_C语言实现的开源 2D 格斗游戏: Punch Kick

    <Punch & Kick>是作者在大学期间用C语言开发的2D格斗游戏,其开源主要是面向开发者及编程爱好者,这款游戏并不适合发烧级玩家.审美帝. 下面是作者自己对这个游戏的介绍: ...

  2. c语言实现通讯录_C语言实现双人猜数字游戏

    点击上方"学士科技",选择"设为星标" 资讯.技术干货第一时间送达! C语言合集(基础.进阶.高级)通通有,点我点我      C语言实例 01.C语言编写简单 ...

  3. 2d游戏地图编辑器_C语言实现大型2D格斗游戏,1.8万行代码!

    这个游戏是从1月初开始写的,现在已经完成了基本的对战功能,共5个角色,可以单人和AI对战,效果如下图所示: 人物动作素材由本人捕捉自FC版游戏<热血格斗>,玩法.游戏效果与<热血格斗 ...

  4. java三子棋人机游戏_C语言编程入门游戏《三子棋》

    经过C语言初级阶段的系统学习,对基本C语言的知识有了一定的了解和认识,能够通过C语言编程解决一些简单的问题.本次完成一个简单的游戏<三子棋>. 游戏简介:常见的3x3棋盘,有两名游戏玩家, ...

  5. c语言做搬山游戏,C语言实现搬山小游戏,适合新手的项目实战,超易上手!

    原标题:C语言实现搬山小游戏,适合新手的项目实战,超易上手! 问题描述 设有n座山,计算机与人作为比赛的双方,轮流搬山.规定每次搬山数不能超过k座,谁搬最后一座谁输. 游戏开始时,计算机请人输入山的总 ...

  6. c语言课程设计之黑白棋游戏,c语言课程设计黑白棋游戏.doc

    您所在位置:网站首页 > 海量文档 &nbsp>&nbsp学术论文&nbsp>&nbsp大学论文 c语言课程设计黑白棋游戏.doc26页 本文档一共被 ...

  7. C语言可以敲哪些小游戏,C语言可以写哪些小游戏?

    C语言可以写哪些小游戏? C语言可以编手机游戏.你叫他去死不过我这有贪吃蛇的代码,你倒可以看看(用TC编译一定过( #包括 #包括 #包括 #包括 #包括 #定义输入7181 #定义ESC 283 # ...

  8. 好玩的c语言编程游戏,C语言写个贪吃蛇游戏

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 C语言写个贪吃蛇游戏 贪吃蛇是个非常经典的游戏,用C语言来实现也是一个好玩的事情.这个游戏我写完后放在知乎,竟然点赞的人数超级多.我觉得大家喜欢,一个方面 ...

  9. bat贪吃蛇游戏代码_C语言写个贪吃蛇游戏

    贪吃蛇是个非常经典的游戏,用C语言来实现也是一个好玩的事情.这个游戏我写完后放在知乎,竟然点赞的人数超级多.我觉得大家喜欢,一个方面是因为写得简单,大家都能看得懂,一个可扩展性还是非常强的. 我试了说 ...

最新文章

  1. KGK荧光喷码机编程指南
  2. Java_异常_04_ OutOfMemoryError系列
  3. 瑞幸咖啡自曝虚假交易 22 亿,App 反冲 TOP 1
  4. SpringBoot+Thymeleaf+ECharts实现大数据可视化(基础篇)
  5. larveral 直接拷贝安装_重新安装网卡驱动的电脑操作
  6. TCP/IP源码分析
  7. 物联网老年人健康管理系统源码
  8. 使用Visio2003更新SQL2005数据库
  9. 祝贺博主新浪微博个人认证与企业微博认证通过,欢迎关注!
  10. 【二次开发应用】安信可ESP32/ESP8266模组入网阿里生活物联网平台
  11. 腾讯云CDN加速COS图床
  12. cf----2019-10-06(Slime,Shashlik Cooking,Mysterious Crime)
  13. OC 需求 检测手机是否安装某个App,app是否安装(删除)appmusic
  14. 算法第二章上机实践报告
  15. 1413 权势二进制
  16. STM32F103C8T6移植uC/OS-III基于HAL库
  17. 【靶机练习】Vulnhub靶场Earth-练习记录
  18. Android-系统服务-settings
  19. LED透明屏多少钱一平方?—实用LED透明屏价格表参考
  20. Win10系统内置实时保护总是无故自动开启该如何将其彻底取消关掉

热门文章

  1. matlab编程读取导航文件文件,基于Matlab读取标准RINEX格式的GPS星历数据
  2. java常用开发286个英语单词汇总
  3. java计算机毕业设计基于安卓Android的二手车交易APP
  4. NFTs是如何在一年里面可以造就400亿美元市场?
  5. js键盘事件中的键码对照表
  6. 苹果怎么录屏?手把手教你搞定掌握小技能!
  7. 【修改huggingface transformers默认缓存文件夹】
  8. linux mysql 误删系统文件恢复_MySQL误删物理文件的恢复(Linux)
  9. 水处理仪器仪表用R型变压器的特点?
  10. 代理Ip池构建及使用