数字拼图游戏中,保证完成的实现方法????

在9个方格中如果出现图中的排列方式,最终是无法完成1~8按顺序排列的,我想问一下许多游戏中能够保证这种排列不出现用到了什么控制方法实现的。或者在数学上什么样的情况下会出现... 在9个方格中如果出现图中的排列方式,最终是无法完成1~8按顺序排列的,我想问一下许多游戏中能够保证这种排列不出现用到了什么控制方法实现的。或者在数学上什么样的情况下会出现这种排列,希望大家帮忙解答,急求!!! 展开
 我来答
随意随缘随心情
2011-05-25 · TA获得超过236个赞
知道小有建树答主
回答量:259
采纳率:40%
帮助的人:125万
展开全部
就我所知道了,目前游戏中的实现方法是按照数字的移动规则随机移动一定次数,移动后的结果与最初的情况对比,如果差异大于多少多少,就生成一个题目,否则就舍弃重新随机
用心明十天
推荐于2016-03-22 · TA获得超过1298个赞
知道小有建树答主
回答量:258
采纳率:100%
帮助的人:195万
展开全部
判断两数字拼图矩阵形式是否可以互换的方法:
将空位移动到与目标矩阵形式相同的位置,计算数列的逆序数奇偶性是否与目标矩阵形式对应数列的逆序数奇偶性相同
一相同的就可以互换
二不同的就不能互换
在设计数字拼图游戏时,只需要相同的输出就可以了
除此之外,还可以用随机函数,从目标矩阵形式开始运行,打乱目标矩阵形式
后就可以得到一个新的矩阵形式,再输出这个新的矩阵形式即可
注:以下是该方法的证明过程,关于“逆序数”,百度里搜一下,你就知道了。

定理:对换改变排列的奇偶性。
证明:设有一数字排列a={s(1),s(2),...,s(k-2),s(k-1),s(k),s(k+1),...,s(n-1),s(n)},任意对换a中相邻两元素s(k-1)和s(k),则
对换产生一个数字排列b={s(1),s(2),...,s(k-2),s(k),s(k-1),s(k+1),...,s(n-1),s(n)}
相邻两元素构成的排列c={s(k-1),s(k)}
相邻两元素构成的排列d={s(k),s(k-1)}
设fx(k)为数字排列x的第k个元素与其后的所有元素的逆序之和,Ex为数字排列x的每一个元素与其后所有元素的逆序之和,简称“逆序数”,
逆序数为奇数的称之为奇排列,逆序数为偶数的称之为偶排列,则
Ea=fa(1)+fa(2)+...+fa(k-2)+fa(k-1)+fa(k)+fa(k+1)+...+fa(n-1)+fa(n)
Eb=fb(1)+fb(2)+...+fb(k-2)+fb(k-1)+fb(k)+fb(k+1)+...+fb(n-1)+fb(n)
因为fa(1)=fb(1),fa(2)=fb(2),...,fa(k-2)=fb(k-2),fa(k+1)=fb(k+1),...,fa(n-1)=fb(n-1),fa(n)=fb(n)
所以Ea-Eb=[fa(k-1)+fa(k)]-[fb(k-1)+fb(k)]
因为数字排列a和数字排列b中的s(k-1)、s(k)与s(k+1)及其后的所有元素的逆序之和相等
所以Ea-Eb=Ec-Ed
当s(k-1)<s(k)时,Ea-Eb=0-1
当s(k-1)>s(k)时,Ea-Eb=1-0
所以Ea±1=Eb,即对换相邻两元素,数字排列的奇偶性改变

推论一:数列进行奇数次相邻对换,数列的奇偶性会改变
推论二:数列进行偶数次相邻对换,数列的奇偶性不改变

假设任意对换a中两元素s(m)和s(k),其中(m<k),则
可以先把s(m)进行k-m次相邻对换,移动到s(k)的位置
s(1),s(2),...,s(m),s(m+1),...,s(k-2),s(k-1),s(k),...,s(n-1),s(n)
s(1),s(2),...,s(m+1),s(m),...,s(k-2),s(k-1),s(k),...,s(n-1),s(n)
...
s(1),s(2),...,s(m+1),s(m+2),...,s(k-1),s(k),s(m),...,s(n-1),s(n)
再把s(k)进行k-m-1次相邻对换,移动到s(m-1)的位置
s(1),s(2),...,s(m+1),s(m+2),...,s(k-1),s(k),s(m),...,s(n-1),s(n)
s(1),s(2),...,s(m+1),s(m+2),...,s(k),s(k-1),s(m),...,s(n-1),s(n)
...
s(1),s(2),...,s(k),s(m+1),...,s(k-2),s(k-1),s(m),...,s(n-1),s(n)
所以总共要进行2(k-m)-1次相邻对换,才可以把s(m)移动到s(k)的位置
因为2(k-m)-1是奇数,所以数字排列的奇偶性改变
综上所述,对换改变排列的奇偶性

在N*N的数字拼图中,
①当空位左或右移动时,
因为数列不变,所以数列奇偶性不变
②当空位上或下移动时,
相当于与空位交换的数字向右或向左相邻对换N-1次
当数字拼图中空位在某位置时,移动空位使其成为任意其他的矩阵形式,最后再将空位回到原位置,则
因为空位要想回到原位置,就必须进行若干次相等的左、右移动和上、下移动(例如,空位向左移动了1次,向右也要移动1次,才能回到原位置)
因为若干次相等的左、右移动不改变数列的奇偶性,若干次相等的上、下移动相当于进行若干个N-1次数字向右相邻对换和若干个N-1次数字向左相邻对换
当N-1为偶数时,数列的奇偶性在数字向右和向左对换时都不改变,最终保持不变
当N-1为奇数时,数列的奇偶性在数字向右和向左对换时都会改变,最终保持不变
所以当空位的位置相同时,可互换的矩阵形式对应的数列奇偶性相同
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式