问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

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

发布网友 发布时间:2022-04-21 19:56

我来回答

2个回答

热心网友 时间:2023-09-27 04:55

就我所知道了,目前游戏中的实现方法是按照数字的移动规则随机移动一定次数,移动后的结果与最初的情况对比,如果差异大于多少多少,就生成一个题目,否则就舍弃重新随机

热心网友 时间:2023-09-27 04:55

判断两数字拼图矩阵形式是否可以互换的方法:
将空位移动到与目标矩阵形式相同的位置,计算数列的逆序数奇偶性是否与目标矩阵形式对应数列的逆序数奇偶性相同
一相同的就可以互换
二不同的就不能互换
在设计数字拼图游戏时,只需要相同的输出就可以了
除此之外,还可以用随机函数,从目标矩阵形式开始运行,打乱目标矩阵形式
后就可以得到一个新的矩阵形式,再输出这个新的矩阵形式即可
注:以下是该方法的证明过程,关于“逆序数”,百度里搜一下,你就知道了。

定理:对换改变排列的奇偶性。
证明:设有一数字排列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为奇数时,数列的奇偶性在数字向右和向左对换时都会改变,最终保持不变
所以当空位的位置相同时,可互换的矩阵形式对应的数列奇偶性相同
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
缘起缘灭美文 个人取得交易手续费返还收入需缴个人所得税吗 个人所得税返还手续费交增值税吗 输血有什么不良反应? 总是梦见很恐怖的快速飞 梦里面还知道自己在做梦想赶紧醒来 问题... 武汉商学院地址是什么 武汉商学院交通方便吗。离市区远吗 武汉商学院地理位置很偏吗 ...2013年10月10日, 农历2013年9月6日, 阴历二零一三癸巳年九月初六日12... 男孩 出 生于2013年10月10日(农历九月初六)凌晨3:07分五行缺什么啊? 数字拼图问题(十五数码) VB javascript数字拼图 求教 如何用C语言制作 数字拼图? 电脑上桌面小工具的数字拼图的方法 二年级数学35页拼图9题,制作一个数字转盘,怎么做 ps做数字内嵌拼图 请教会数字拼图的高手~~~~这样该怎么弄?? 国有三不祥体现了晏子怎样的治国理想 国有三不祥中,晏子借什么机会,巧妙向君王进谏,... 国有三不祥文言文翻译 wap.5156edu.com 国有三不祥晏子劝谏有何特点 国有三不祥,晏子借为景公解惑的机会,向景公提了... 景公出猎 国有三不祥含义 国有三不祥文言文晏子是什么样的人 文言文阅读 国有三不祥 景公出猎,上... 你能谈谈对典故“国有三不详”的理解吗? 国有三不祥带来了什么 文言文《国有三不详》的翻译 国有三不祥的原文 《国有三不祥》晏子借什么的机会,巧妙向君王进谏... 数字拼图怎么拼!!!求救!!! 哪有能将图片转换成数字拼图形式的软件 3*3的VB数字拼图怎么做 ? VB九宫数字拼图游戏 数字拼图 治疗类风湿的土方法有哪些 类风湿关节炎有没有偏方可以治疗 怎样写感谢信给资助我的人 类风湿关节炎的治疗有啥偏方嘛? 急求一份对个人爱心助学的感谢信 治疗类风湿关节炎最有效的偏方? 治疗类风湿的土方法 怎么写对方给我的爱心资助的感谢信 类风湿特效偏方? 助学金的感谢信怎么写 类风湿关节炎偏方 求帮忙,求各位朋友! “爱心助学”感谢词怎么写 求救,类风湿关节炎最有效的偏方… 类风湿有什么偏方吗?很痛苦,该怎么去治疗类风湿呀? 初中生助学金感谢信