美文网首页C语言C语言C++编程学习我爱编程
C语言实现扫雷小程序外挂,棒棒的

C语言实现扫雷小程序外挂,棒棒的

作者: C语言学习 | 来源:发表于2018-07-30 18:21 被阅读3次

    今天跟大家分享的是“扫雷外挂”!!!

    0.扫雷外挂效果图

    1.分析扫雷图像

    下面的代码可以得到一个点的颜色,核心代码是GetPixel。

    2.模拟鼠标操作

    其实鼠标操作我知道的有两种,一种是下面写的这种

    还有种是:

    3.扫雷外挂流程分析

    看起来比较复杂的流程,我本来用while的,比较难搞,最后用了Goto,流程就变得非常清晰。还弄了一个struct做为标志传进去分析,看分析是什么结果,决定goto到哪个步骤。小编推荐一个学C语言/C++的学习裙【 六二七,零一二,四六四 】,无论你是大牛还是小白,是想转行还是想入行都可以来了解一起进步一起学习!裙内有开发工具,很多干货和技术资料分享!

    4.分析扫雷游戏

    来讲下最难的部分:就是上图中的进行组合分析。

    a + b = 1

    a + b + c = 1

    要得出c = 0

    我用一个类叫CellCombination来表示一个子项,它有N多个格子的坐标组成。还有一个Int来存总的雷数。我还记录了是哪个格子产生的子项。

    当我们分析一个格子周围8个格子的情况时候,如果发现有多解的情况下,就产生一个子项。然后通过两两子项相减,来确定一些格子的状态。

    a + b = 1

    a + b + c = 1

    c + d + e = 2

    f + g + h = 1

    如何通过两两相减呢?比如一共产生了上面4个子项。就是4个里面选2个进行操作。就是一个组合算法。可以用我上次写的算法组合算法 C++高效实现 (二进制辅助法)。如果一共有10个子项,一共有10 * 9 / 2 即45次比较。如果一共有20个子项,一共有20 * 19 / 2 即190次比较。算法效率也不是特别高。

    经过实战分析后,我发现扫雷中会有很多格子数量是2的子项,比如a + b = 1,但是两个这样的子项是不会产生结果的。 所以我先对所有子项进行排序,从尾部开始往前移动,移到数量是2的就退出了。另外一个来指向当前前一个,直到第一个。

    如何进行两个子项相减呢?先把教长的子项拷贝一份,然后循环短的子项中的每一个点,每找到一个结果就从长的子项的vector中删除一个。进行两个子项相减的程序就不列出来了,也做了很多优化,如果两个子项的长度是一样的,就直接退出,不会有结果的,还有如果两个子项的ParentCell距离比较远,可肯定不会有结果。如果有一个找不到就退出,也是不会有结果的。

    相关文章

      网友评论

        本文标题:C语言实现扫雷小程序外挂,棒棒的

        本文链接:https://www.haomeiwen.com/subject/jkxqvftx.html