codecamp

拼图游戏打乱后不可还原解决办法


自己做了一个拼图小游戏,大概如下:

1      2      3 

4      5      6

7      8      0

0是空白位置,每次按照随机的顺序重新排列,但是不是每次排列后都可能被还原,例如:

1     2      3

4     5     6

8     7     0

这样是复原不了的



----------------------割----------------------------

第一种解决办法:

后来查了一些方法,其中有提到“反序数”的概念,通过两个矩阵的反叙述奇偶是否相同,可以判断两个矩阵,其中一个矩阵是否可以通过相邻位置的对象两两互换位置后调整成另外一个矩阵。

反序数

但是亲测后发现只用反叙数判断还是没能成功,因为拼图游戏只能通过“0”位(空白位置)和其相邻的位置进行互换。

这里判断还需要加上两个矩阵空白位置所在矩阵的行列数进行判断。


以上面的矩阵为例子,

第一个矩阵空白块所在位置为 a[2][2]. 反序数为0

和为: sum = 2 + 2 + 0 ; sum = 4;

第二个矩阵空白块所在位置是 a[2][2],反序数为3

和为:sum = 2 +2 + 3 = 7;


0 为偶数,3为奇数,所以第二个矩阵是不能转换成第一个矩阵的,也就是如果拼图打乱成这个顺序是不能被还原的。


第二种解决办法:

让空白格随机和周边的方块交换位置,这样这样走几十步就可以了,而且一定可以复原。




参考文档:

一群大神的舌枪唇战,可以参考,但是没有什么实际性的作用;

拼图里面,一张图片应该以么样的算法打乱,才能够保证有解?

不可还原的拼图

适合拼图游戏的打乱算法讲解

计算拼图的步数





iOS8 定位当前城市
iOS 日志工具
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }