首页 > 其他分享 >puzzle(103.1)网格图一笔画

puzzle(103.1)网格图一笔画

时间:2022-10-21 14:04:24浏览次数:81  
标签:终点 格子 puzzle 路径 相邻 103.1 图一 分割线 定理


目录

​一,一笔画完(网格图带起点)​

​二,网格图不带起点​

​三,六边形网格图​


一,一笔画完(网格图带起点)

一笔画完(微信小程序游戏):

puzzle(103.1)网格图一笔画_分割线

这个游戏和我攻略过的另外2个游戏相关性较高:同一个世界​、一笔画2

和一笔画2不一样,一笔画完这个游戏是给出了起点的。

本文介绍了这个游戏的规律和策略,总结成了五个定理和一个三个策略。

首先定义几个名词:

邻居:每个点最多有4个邻居,即上下左右

:邻居的个数,范围是1-4

格子总数:开局状态所有格子的数量

唯一终点:有的局面有唯一终点,即只有一个格子可以是终点。有的局面有多个格子可以是终点。

路径:由一连串相邻的点构成的有序列表。

然后我们来解决第一个问题,如何寻找终点

定理一:起点到终点的曼哈顿距离的奇偶性和格子总数的奇偶性不同。

利用这个定理,就可以排除一半的格子了。

定理二:如果有个格子(不是起点)度为1,那么它就是唯一终点

接着我介绍一个有效的化简局面的方法

定理三:如果一个格子(不是起点或终点)的度为2,那么它的2个邻居在路径中一定是和它相邻的。

以第50关为例:

puzzle(103.1)网格图一笔画_坐标轴_02

首先利用定理二很容易找到格子E就是唯一终点。

puzzle(103.1)网格图一笔画_曼哈顿距离_03

接着我们可以找到7个可以应用定理三的格子

于是我们得到:

puzzle(103.1)网格图一笔画_算法_04

到这里答案就一目了然了。

顺便解释一下定理一:起点到终点的曼哈顿距离是3+4=7,格子总数是26,奇偶性是不同的。

因为度很重要,所以这里不得不介绍一个重要的思想:

策略一:度的动态算法:

在寻找某条路径的时候,经过推理我们判断出格子A和它的邻居B在这条路径中的排序是不相邻的,那么在计算A的度的时候可以直接不算入B

注1:不一定在所有路径中A和B都不相邻。

注2:如果经过推理我们判断出格子A和它的邻居B在任何路径中的排序都是不相邻的,那么在计算A的度的时候可以直接不算入B,这不影响我们找到任何一条路径。

以第60关为例:

puzzle(103.1)网格图一笔画_分割线_05

用定理二很容易找到格子E就是唯一终点,再用定理三得到:

puzzle(103.1)网格图一笔画_曼哈顿距离_06

接着我们发现有2个格子(画圆圈的格子)可以利用度的动态算法把度看做2,于是再利用定理三得到:

puzzle(103.1)网格图一笔画_坐标轴_07

重复这个过程得到:

puzzle(103.1)网格图一笔画_曼哈顿距离_08

再重复这个过程得到:

puzzle(103.1)网格图一笔画_坐标轴_09

至此,唯一路径就直接得到了。

之所以是唯一路径,参考度的动态算法的注2

接着再介绍一个我发明的非常厉害的分割法:

定理四(分割法一)

如果有一条分割线(不一定是直线)不穿过格子只经过格子之间的缝隙,把整个局面分为A、B两块

且A块中只有1个格子P1和这条分割线相邻,P1唯一的属于B块的邻居是P2,

那么起点S和终点E不在分割线同一侧,且路径一定跨过这条分割线1次。

而且,AB两块可以分别求子路径,P1和P2分别是新增起点和新增终点,最后把P1和P2相连,2条子路径合并得到的最终路径即为所求

定理五(分割法二)

如果有一条分割线(不一定是直线)不穿过格子只经过格子之间的缝隙,把整个局面分为A、B两块

如果AB都有且只有2个格子和这条分割线相邻,此时假设起点S在A块,A块和分割线相邻的格子是P1、P2,B块和分割线相邻的格子是P3、P4,且P1和P3相邻,P2和P4相邻(P1P2不一定相邻,P3P4不一定相邻)

那么根据起点和终点的位置可以分为两种情况:

(1)起点和终点都在A侧,那么路径一定跨过这条分割线2次,

而且AB两块可以分别找到满足下面条件的子路径:A块中P1和P2相连(即使P1P2不是邻居),B块中P3和P4即为起点和终点

于是2条子路径即可merge为最终路径

(2)起点和终点不在同一侧,那么路径一定跨过这条分割线1次,

于是要么P1和P3最终不相邻,要么P2和P4最终不相邻,于是利用度的动态算法,这种情况即退化为定理四

以第66关为例:

puzzle(103.1)网格图一笔画_分割线_10

画一条非常厉害的分割线:

puzzle(103.1)网格图一笔画_算法_11

那么这就是定理五的第(2)种情况

因为根据定理三可知,P1和P3是相邻的,所以P2和P4是不相邻的。

于是退化为定理四,在A块寻找S到P1的路径,在B块寻找P3到E的路径,然后merge得到最终路径。

puzzle(103.1)网格图一笔画_坐标轴_12

再以图72关为例:

puzzle(103.1)网格图一笔画_曼哈顿距离_13

画一条非常厉害的分割线:

puzzle(103.1)网格图一笔画_分割线_14

那么这就是定理五的第(1)种情况

puzzle(103.1)网格图一笔画_分割线_15

接着我介绍一个非常常见的场景:

经常遇到,起点走到终点,却缺了2个格子的情况,例如第123关:

puzzle(103.1)网格图一笔画_曼哈顿距离_16

这时,我们可以通过策略二——变形,解决这个问题:

puzzle(103.1)网格图一笔画_算法_17

策略二比较简单,我就不描述了。

再比如第124关:

puzzle(103.1)网格图一笔画_分割线_18

变形为:

puzzle(103.1)网格图一笔画_分割线_19

再来介绍策略三:边界切割:

如果起点或者终点在角落或靠近角落的边界位置,可以把这个格子所在的最旁边两行或者两列切割出来,看看能否通过分块解决这个问题。

比如第217关:

puzzle(103.1)网格图一笔画_分割线_20

终点在左上角,如果切除左边2列,很容易得到:

puzzle(103.1)网格图一笔画_算法_21

如果切除上面2行,也很容易得到:

puzzle(103.1)网格图一笔画_曼哈顿距离_22

实际上,这个规律可以拓展成一般规律:

绝大部分关卡都存在这样的一个解:存在某条平行于坐标轴的直线把路径分为两部分,整条路径只跨越这条直线一次,即这条直线刚好把路径分为左右两块或上下两块。

从217关往后就再也没有什么新发现了,基本上都是一样的,下面列出我玩过的所有关卡及其答案:

puzzle(103.1)网格图一笔画_算法_23

puzzle(103.1)网格图一笔画_分割线_24

puzzle(103.1)网格图一笔画_坐标轴_25

puzzle(103.1)网格图一笔画_曼哈顿距离_26

puzzle(103.1)网格图一笔画_曼哈顿距离_27

puzzle(103.1)网格图一笔画_坐标轴_28

puzzle(103.1)网格图一笔画_算法_29

puzzle(103.1)网格图一笔画_坐标轴_30

puzzle(103.1)网格图一笔画_分割线_31

puzzle(103.1)网格图一笔画_曼哈顿距离_32

puzzle(103.1)网格图一笔画_曼哈顿距离_33

puzzle(103.1)网格图一笔画_算法_34

puzzle(103.1)网格图一笔画_曼哈顿距离_35

puzzle(103.1)网格图一笔画_坐标轴_36

puzzle(103.1)网格图一笔画_分割线_37

puzzle(103.1)网格图一笔画_曼哈顿距离_38

puzzle(103.1)网格图一笔画_曼哈顿距离_39

puzzle(103.1)网格图一笔画_算法_40

puzzle(103.1)网格图一笔画_分割线_41

puzzle(103.1)网格图一笔画_分割线_42

puzzle(103.1)网格图一笔画_分割线_43

puzzle(103.1)网格图一笔画_算法_44

puzzle(103.1)网格图一笔画_曼哈顿距离_45

puzzle(103.1)网格图一笔画_算法_46

puzzle(103.1)网格图一笔画_曼哈顿距离_47

puzzle(103.1)网格图一笔画_算法_48

puzzle(103.1)网格图一笔画_曼哈顿距离_49

puzzle(103.1)网格图一笔画_分割线_50

puzzle(103.1)网格图一笔画_曼哈顿距离_51

puzzle(103.1)网格图一笔画_坐标轴_52

puzzle(103.1)网格图一笔画_坐标轴_53

puzzle(103.1)网格图一笔画_坐标轴_54

puzzle(103.1)网格图一笔画_分割线_55

puzzle(103.1)网格图一笔画_坐标轴_56

puzzle(103.1)网格图一笔画_坐标轴_57

puzzle(103.1)网格图一笔画_坐标轴_58

puzzle(103.1)网格图一笔画_算法_59

puzzle(103.1)网格图一笔画_算法_60

puzzle(103.1)网格图一笔画_曼哈顿距离_61

puzzle(103.1)网格图一笔画_曼哈顿距离_62

puzzle(103.1)网格图一笔画_曼哈顿距离_63

puzzle(103.1)网格图一笔画_分割线_64

puzzle(103.1)网格图一笔画_曼哈顿距离_65

puzzle(103.1)网格图一笔画_分割线_66

puzzle(103.1)网格图一笔画_曼哈顿距离_67

puzzle(103.1)网格图一笔画_坐标轴_68

puzzle(103.1)网格图一笔画_分割线_69

puzzle(103.1)网格图一笔画_坐标轴_70

puzzle(103.1)网格图一笔画_分割线_71

puzzle(103.1)网格图一笔画_坐标轴_72

puzzle(103.1)网格图一笔画_坐标轴_73

puzzle(103.1)网格图一笔画_算法_74

puzzle(103.1)网格图一笔画_坐标轴_75

puzzle(103.1)网格图一笔画_坐标轴_76

puzzle(103.1)网格图一笔画_坐标轴_77

二,网格图不带起点

隐匿按钮的第(49)关

puzzle(103.1)网格图一笔画_分割线_78

三,六边形网格图

​4399在线play​

(1) 

puzzle(103.1)网格图一笔画_坐标轴_79

puzzle(103.1)网格图一笔画_算法_80

(2)

puzzle(103.1)网格图一笔画_曼哈顿距离_81

  

puzzle(103.1)网格图一笔画_算法_82

黄色框要走2遍。

(3)

puzzle(103.1)网格图一笔画_坐标轴_83

  

puzzle(103.1)网格图一笔画_坐标轴_84

(5)

puzzle(103.1)网格图一笔画_算法_85

 

puzzle(103.1)网格图一笔画_分割线_86

 (8)

puzzle(103.1)网格图一笔画_曼哈顿距离_87

  

puzzle(103.1)网格图一笔画_曼哈顿距离_88

(10)

puzzle(103.1)网格图一笔画_算法_89

  

puzzle(103.1)网格图一笔画_分割线_90

 绿色格子是传送门

 (11)

puzzle(103.1)网格图一笔画_分割线_91

  

puzzle(103.1)网格图一笔画_算法_92

带旋转按钮的格子,每次到达这个格子都会带动周围6个格子旋转。

(13)

puzzle(103.1)网格图一笔画_坐标轴_93

 

 

 

 

 

标签:终点,格子,puzzle,路径,相邻,103.1,图一,分割线,定理
From: https://blog.51cto.com/u_15458280/5782601

相关文章

  • CF627F Island Puzzle.
    容易观察到一次操作是将\(0\)移动到一个相邻的节点上,而且操作可逆转。所以对于不加边的情况方案是唯一的,直接模拟一下看看是不是相等的就好。对于加一条边来说,我们先将......
  • vue-puzzle-vcode与vue-drag-verify纯前端的拼图人机验证、右滑拼图验证
    转载作品!以获取原作者允许,原文地址,感觉写的比较全面,也比较实用,大家可以去看看原文章;纯前端的拼图人机验证、右滑拼图验证1、vue-puzzle-vcodegithub地址:https://github......
  • 直方图(不是和条形图一样吗?)
    直方图(不是和条形图一样吗?)由Freepik创建的直方图图标—Flaticon当我要选择时出现的第一个问题直方图呈现数据是“不是条形图吗?”因为如果我们看形状,它们看起来很......
  • 智能证件照api——可立图一键抠图工具
    可立图是一家可以在线智能抠图的网站,同时也可以一键生成证件照提供了抠图api服务和证件照api服务注册可立图官网后可获取免费接口次数1.证件照接口地址:https://www.cli......
  • CodeForces-1472F New Year's Puzzle
    NewYear'sPuzzle模拟如果尝试从左到右放,就会发现其实放的基本是唯一的,因此考虑直接模拟就好了针对当前列,分成三种状态:状态\(0\):上下都不能放状态\(1\):下面不......
  • CF713D Animals and Puzzle
    题意:\(n*m\)矩阵,每个点为0或1,每次给定一个矩形区间,问最大能够画出边长为多少的正方形保证正方形内的每一个数都是1.首先是动规。f[i][j]表示以(i,j)点位左下角的正方......