python实现消消乐游戏_C语言实现消消乐游戏
本文实例为大家分享了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语言实现消消乐游戏相关推荐
- python编写格斗游戏_C语言实现的开源 2D 格斗游戏: Punch Kick
<Punch & Kick>是作者在大学期间用C语言开发的2D格斗游戏,其开源主要是面向开发者及编程爱好者,这款游戏并不适合发烧级玩家.审美帝. 下面是作者自己对这个游戏的介绍: ...
- c语言实现通讯录_C语言实现双人猜数字游戏
点击上方"学士科技",选择"设为星标" 资讯.技术干货第一时间送达! C语言合集(基础.进阶.高级)通通有,点我点我 C语言实例 01.C语言编写简单 ...
- 2d游戏地图编辑器_C语言实现大型2D格斗游戏,1.8万行代码!
这个游戏是从1月初开始写的,现在已经完成了基本的对战功能,共5个角色,可以单人和AI对战,效果如下图所示: 人物动作素材由本人捕捉自FC版游戏<热血格斗>,玩法.游戏效果与<热血格斗 ...
- java三子棋人机游戏_C语言编程入门游戏《三子棋》
经过C语言初级阶段的系统学习,对基本C语言的知识有了一定的了解和认识,能够通过C语言编程解决一些简单的问题.本次完成一个简单的游戏<三子棋>. 游戏简介:常见的3x3棋盘,有两名游戏玩家, ...
- c语言做搬山游戏,C语言实现搬山小游戏,适合新手的项目实战,超易上手!
原标题:C语言实现搬山小游戏,适合新手的项目实战,超易上手! 问题描述 设有n座山,计算机与人作为比赛的双方,轮流搬山.规定每次搬山数不能超过k座,谁搬最后一座谁输. 游戏开始时,计算机请人输入山的总 ...
- c语言课程设计之黑白棋游戏,c语言课程设计黑白棋游戏.doc
您所在位置:网站首页 > 海量文档  > 学术论文 > 大学论文 c语言课程设计黑白棋游戏.doc26页 本文档一共被 ...
- C语言可以敲哪些小游戏,C语言可以写哪些小游戏?
C语言可以写哪些小游戏? C语言可以编手机游戏.你叫他去死不过我这有贪吃蛇的代码,你倒可以看看(用TC编译一定过( #包括 #包括 #包括 #包括 #包括 #定义输入7181 #定义ESC 283 # ...
- 好玩的c语言编程游戏,C语言写个贪吃蛇游戏
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 C语言写个贪吃蛇游戏 贪吃蛇是个非常经典的游戏,用C语言来实现也是一个好玩的事情.这个游戏我写完后放在知乎,竟然点赞的人数超级多.我觉得大家喜欢,一个方面 ...
- bat贪吃蛇游戏代码_C语言写个贪吃蛇游戏
贪吃蛇是个非常经典的游戏,用C语言来实现也是一个好玩的事情.这个游戏我写完后放在知乎,竟然点赞的人数超级多.我觉得大家喜欢,一个方面是因为写得简单,大家都能看得懂,一个可扩展性还是非常强的. 我试了说 ...
最新文章
- SharePoint优秀blog文章汇总
- PL/SQL在win7/win8 x64位下使用客户端连接oracle
- 看动画学算法之:队列queue
- 在VUE中利用MQTT协议实现即时通讯
- Linux断点方法,一种基于Linux问题断点的定位方法及系统与流程
- 信息学奥赛C++语言:咪咪的智慧
- Idea中maven项目中导入本地jar包
- 如何在 Mac 上自动启用隐藏式字幕?
- 惠普服务器c盘格式化提示win7系统盘,c盘格式化,小编告诉你怎么格式化c盘
- GreenPlum常用数值计算函数
- 计算机颜色更换,如何给证件照换底色;怎么快速更换证件照底色
- flash 交互操作:裁剪位图
- 《让荧光舞一直挥舞下去》
- 河南省赛 导弹发射 lis
- matlab diff函数用法_Matlab-计算机代数工具箱
- java 数组的行数和列数
- 巨头“围攻”之下,新氧医美能否“破局”?
- Vertx3入门应用
- python函数基础
- HGAME2021部分逆向WP