【Qt编程】Qt版扫雷
学习要学会举一反三。在以前的《用matlab扫扫雷》一文中,我用matlab简单的编写了一个扫雷小程序。当然,与Windows自带的扫雷程序自然是不敢相提并论。今天我就用c++来写个扫雷程序,算是对c++的练习。在那篇文章中提过,扫雷问题是NP完全问题,不能被解决。网上也有人做过扫雷的辅助工具,但也只是指明肯定是雷、和肯定不是雷的位置,不能完全求解。下面来讲述我的程序设计思路:
1.用随机数生成雷分布的矩阵,元素为0表示无雷,1表示有雷。
2.通过循环遍历来统计一个元素的周围与之相邻的8个元素的雷的个数。
3.当鼠标左击某个按钮时,如果有雷则游戏失败。如果没有雷且其周围8个位置雷的个数为0,则将周围的8个位置打开,如果这8个位置中还有元素的周围8个元素个数为0,则将它周围的8个位置打开,依次类推……。知道将所有雷都标记正确,游戏胜利。
游戏的缺点:
1.由于时间关系,没有对游戏的界面进行美化,因此界面比较简陋。
2.与Windows自带的扫雷相比,少了几点功能,如果学了QML可能效果会好一点,但是不影响正常使用。
3.没有对代码进行优化,代码可能显得冗余。
在编写过程中想到的:卷积的妙用
在统计一个元素与之相邻的8个元素的雷的总个数的时候,一般最容易想到的是用遍历来统计:
int x1,x2,x3,x4,x5,x6,x7,x8;//分别表示周围的8个位置的行
int y1,y2,y3,y4,y5,y6,y7,y8;//分别表示周围的8个位置的列
int count=0;//统计雷的个数
for(row=0;row<9;row++)
for(col=0;col<9;col++)
{
x1=row-1;y1=col-1;
x2=row-1;y2=col;
x3=row-1;y3=col+1;
x4=row;y4=col-1;
x5=row;y5=col+1;
x6=row+1;y6=col-1;
x7=row+1;y7=col;
x8=row+1;y8=col+1;
if(x1>=0&&y1>=0)//需要判断行和列是否越界
if( minefield[x1][y1]==1)
count=count+1;
if(x2>=0)
if( minefield[x2][y2]==1)
count=count+1;
if (x3>=0&&y3<9)
if (minefield[x3][y3]==1)
count=count+1;
if (y4>=0)
if (minefield[x4][y4]==1)
count=count+1;
if (y5<9)
if (minefield[x5][y5]==1)
count=count+1;
if(x6<9&&y6>=0)
if (minefield[x6][y6]==1)
count=count+1;
if(x7<9)
if (minefield[x7][y7]==1)
count=count+1;
if(x8<9&&y8<9)
if( minefield[x8][y8]==1)
count=count+1;
countnum[row][col]=count;
count=0;
}
上面的程序通俗易懂,但是需要经过多次的条件判断来保证数组的下标不越界。在matlab中我们可以通过一条语句则可以解决上述问题。
看下面的例子:
上图中,a就是雷的分布矩阵,1表示雷区。b是我们自己设置的一个特殊矩阵。c就是我们需要得到的雷的个数的矩阵,其中的含义如下:
c[0][0]=2,表示以a[0][0]为中心的九宫格中的雷的个数(自己的没有算在内)。那么c是如何得到的呢?正如上面所说,只需要一条命令即可:c=conv2(a,b,'same')。也就是求a矩阵和b矩阵的卷积!
当然矩阵的卷积我们在《信号与线性系统分析》中没有讲到,但是书中提到了一维向量的卷积。例如:
a=[1 2 3]; b=[4 5 6];
则a与b的卷积为c=conv(a,b)=[ 4 13 28 27 18];
具体的计算过程可以通过公式计算,下面用比较简单的方法来计算上面的卷积:
上面的计算方法和小学学的乘法好像一样,在我印象中,两个信号这样求卷积的前提好像是这两个信号都是因果信号,唉,具体是什么条件我也不是很清楚了。在这里来说,就不用管这些条件限制。
矩阵的卷积归根到底可以转换成一维向量的卷积,具体的做法是(以第一次的例子的值为例):首先,将一个矩阵选择180度,这里我们选择b矩阵,碰巧b矩阵选择后的矩阵b1和原矩阵b一样;然后将b1矩阵每次往下移一行,将b1与a矩阵在同一行的一行分别进行一维向量的卷积运算,然后对应的列相加起来合并为一行。具体过程图解如下:
综上所述:a与b的卷积是
1 1 2 1 1
这与c=conv2(a,b)的结果相同!而在我的扫雷程序中想要得到的是与a相同维数的矩阵,因此我们可以使用 c=conv2(a,b,'same')来得到我们的结果。
在前面的讨论中,我们使用的b矩阵是b=[1 1 1;1 0 1;1 1 1]。b的选取与我要的结果有关,如果我需要的是九宫格中所有的雷的个数(包含中心格) ,我们可以令b=[1 1 1;1 1 1;1 1 1];验证结果如下:
如果我们选择b=[1 1 1;1 1 0;1 1 1],那么相当于不把中心格右边的雷计算在内,验证如下:
到目前为止,其中的规律就不言而喻了。
不知不觉一天就过去了,导师的报告还没写,就此搁笔。
程序运行截图如下:
1.开始的界面:
2.输了的界面:
3.赢了的界面:
程序下载请访问: http://pan.baidu.com/s/1kzntk
原文:http://blog.csdn.net/tengweitw/article/details/23378983
作者:nineheadedbird
【Qt编程】Qt版扫雷的更多相关文章
- Qt编程简介与基本知识
1. 什么是Qt? Qt是一个基于C++的跨平台应用程序和UI开发框架.它包含一个类库,和用于跨平台开发及国际化的工具. 由挪威Trolltech公司开发,后被Nokia收购,目前被Digia公司收购 ...
- 学习 Qt 编程的好书精品推荐!
最近一段时间,准备开始搞Qt方面的东西,想找几本书看看.网上介绍QT的书籍也有很多,不想浪费时间,所以想找几本精品的书籍来看.花了半天的时间找了几本非常不错的,这里面整理好之后推荐给大家! 下面介绍的 ...
- qt编程入门
面对qt编程,必须先知道qt中常用的类: QPushButton按钮类.QLabel标签类.QMessageBox对话框类.QCheckBox.QAction.QMenu.QStatusBar.QTo ...
- Visual Studio下Qt编程中对中文的处理
Visual Studio下Qt编程中对中文的处理 本文为原创文章,原文地址http://www.cnblogs.com/c4isr/p/qt_develop_in_vs.html Visual St ...
- QT笔记(1)--QT编程环境搭建
一.QT简介 Qt 是一个1991年由奇趣科技开发的跨平台C++图形用户界面应用程序开发框架.它既可以开发GUI程序,也可用于开发非GUI程序,比如控制台工具和服务器.Qt是面向对象的框架,使用特殊 ...
- Qt编程学习网站
http://blog.csdn.net/k122769836/article/details/8637677 QT - little_su - 博客频道 - CSDN.NET Qt - 1+1=2 ...
- 在windows下的QT编程中的_TCHAR与QString之间的转换
由于在windows下的QT编程中,如果涉及到使用微软的API,那么不可避免使用_TCHAR这些类型,因此在网上查了一下,其中一个老外的论坛有人给出了这个转换,因此在这里做一下笔记 : )#ifdef ...
- QT编程环境搭建
使用QT需要QT的库以及QT creator,在QT5以后的版本中,两者已经集成,不需要单独下载了,只需要下载一个文件即可.配置步骤如下: 1.下载qt-opensource-windows-x86- ...
- 【Qt编程】基于Qt的词典开发系列<五>--无边框窗口的拖动
在上一篇文章中,我们讲述了如何进行无边框窗口的缩放与拖动,而在一些情况下,我们的窗口只需要进行拖动也不需要改变其大小,比如:QQ的登录窗口.本来在上一篇文章中已经讲述了如何进行窗口的拖动,但是却与窗口 ...
- Qt编程之悲惨世界
最近需要给人写点基于QtWebkit的代码,算是领教了Qt编程的痛苦之处. QNetworkConfigurationManager::isOnline() 只有在编译平台上能运行,拷贝到其他Wind ...
随机推荐
- Objective-C与Java类的一些区别
Objective-C与Java类的一些区别 OC类和C一样,需要有声明和定义,先上一段OC代码 #import <Foundation/Foundation.h> /* * 声明一个Pe ...
- Android Studio精彩案例(四)《DrawerLayout使用详解仿网易新闻客户端侧边栏 》
转载本专栏文章,请注明出处,尊重原创 .文章博客地址:道龙的博客 为了提高兴趣,咱们开头先看看最终要实现什么样的效果: 侧拉菜单在Android应用中非常常见,它的实现方式太多了,今天我们就说说使用G ...
- 【mybatis深度历险系列】mybatis中的高级映射一对一、一对多、多对多
学习hibernate的时候,小编已经接触多各种映射,mybatis中映射有到底是如何运转的,今天这篇博文,小编主要来简单的介绍一下mybatis中的高级映射,包括一对一.一对多.多对多,希望多有需要 ...
- Spring基础配置
从毕业到现在我一直从事Android开发,但是对JavaEE一直念念不忘,毕业校招的时候,一个礼拜拿了三个offer,岗位分别是Android.JavaEE和JavaSE,后来觉得Android比较简 ...
- 使用Dialog实现全局Loading加载框
Dialog实现全局Loading加载框 很多人在实现Loading加载框的时候,都是在当前的页面隐藏一个Loading布局,需要加载的时候,显示出来,加载完再隐藏 使用Dialog实现Loading ...
- Spark技术内幕:Shuffle Read的整体流程
回忆一下,每个Stage的上边界,要么需要从外部存储读取数据,要么需要读取上一个Stage的输出:而下边界,要么是需要写入本地文件系统(需要Shuffle),以供childStage读取,要么是最后一 ...
- 破解Oracle ERP 密码
1. 写作目的 1 2. 利用Toad或其它pl/sql工具在Oracle ERP Database中建立Package,源码如下 1 (1). ...
- ScrollView的阻尼回弹效果实现(仿qq空间)
玩过新浪微博,qq空间等手机客户端的童鞋,都应该清楚,在主界面向下滑动时,会有一个阻尼回弹效果,看起来挺不错,接下来我们就来实现一下这种效果,下拉后回弹刷新界面,先看效果图: 这个是编辑器里面的界面效 ...
- Struts 2之Servlet API
Struts 2对Servlet API进行了封装,是业务层更加独立,如果需要调用Request.Response等Servlet API有两种途径 利用ServletActinContext的静态方 ...
- OpenMP基础----以图像处理中的问题为例
OpenMP2.5规范中,对于可以多线程执行的循环有如下5点约束: 1.循环语句中的循环变量必须是有符号整形,如果是无符号整形就无法使用,OpenMP3.0中取消了这个约束 2.循环语句中的比 ...