魔方吧·中文魔方俱乐部

 找回密码
 注册
搜索
热搜: 魔方
查看: 230728|回复: 11
打印 上一主题 下一主题

回到最初,从52步的 Thistlethwaite 开始(2) [复制链接]

Rank: 4

积分
1960
帖子
1075
精华
6
UID
17579
性别
保密

魔方理论探索者 论坛建设奖 六年元老

跳转到指定楼层
1#
发表于 2011-2-9 12:13:23 |只看该作者 |倒序浏览
要用c代码实现一个Thistlethwaite算法。
代码要尽量写的美观、工整,易读。
效率先不要求。

(1)表存储什么?
    存储深度,状态转移,
   
(2)是否要把每个阶段的算法“统一”起来?
   诸多简短的实现都使用了“统一”的搜索形式。四个阶段用一个search函数。
   让函数根据参数判断是那个阶段的搜索。
   因为,即使分开来写,也会发现,四个搜索函数的格式基本一样。
   所以,大都倾向于“统一”形式。
   可先分开写,然后法统一。

[ 本帖最后由 aubell 于 2011-2-12 17:06 编辑 ]
Enjoy cubing
Enjoy coding.
我喜欢的公式 U D F2 B2 U' D'

Rank: 4

积分
1960
帖子
1075
精华
6
UID
17579
性别
保密

魔方理论探索者 论坛建设奖 六年元老

2#
发表于 2011-2-9 12:14:50 |只看该作者
占楼备用。这一层写基础代码。总体分析等。

代码已经完工。待继续美化、优化以后陆续贴出。
其实很有些凌乱,要慢慢整理好看一点。

实现上,生成的表很大。每个int用了四个字节存储,总共用了大约 20M。
改进以后,每个int其实可以改成BYTE,由于存储深度值,不会太大。
这样可以把表缩小到 5M。

由于每一步深度值不会太大,肯定不会超过32,那么用5个bit就够了;
不过,这个增加运算复杂度,实在没必要这样压缩空间。

现在机器的内存那么大,诶,真觉得用所谓“对称”减小存储量没有必要了。
但如果能利用“对称”搜索更短的公式,倒是很有趣的。

发现当前的实现在G3进入G4的时候,不是简单的进入了G4,而是不小心进入
了G4的一个子集,角都处于还原状态了!这样增加了phase3的使用的步数,而phase4
的步数也没有降低。大约长了3步。

现在存在的问题是,初始运行,生成“深度表”的时间太长了,大约用了3-5分钟。
真不知道高人TomasSirgedas是如何用150行完成的Thistlethwaite的,而且没有什么
等待时间,没有外部的表。有空把他的代码解剖一下。

(那些高效的代码基本都是不“转”魔方的,而是直接“看”魔方的状态。
存储好像都不太用线性表,而用hash表。



功能模块:
1. 排列、组合同数字之间的转化
2. 可以转动的魔方
3. 魔方状态的设定和获取
4. 状态深度表
5. 状态查找函数

“设定”到特定状态导致魔方状态的“不完整”,
这种方法感觉稍别扭;
争取改“转动到”某些状态。
使得只有获取状态的函数,没有设定状态的函数。

对称好像真的很麻烦。
用“整体翻转”和“镜像”?

要解析jaap,pochman,TomasSirgedas三个人的代码,
自己的准备重写了。

5分钟的初始化时间,那三个程序都能解数以万计的
魔方了。


奇怪的是Parity好像没有单独处理也可以啊?
莫非Parity本来就不用单独处理??

[ 本帖最后由 aubell 于 2011-2-12 16:18 编辑 ]
Enjoy cubing
Enjoy coding.
我喜欢的公式 U D F2 B2 U' D'

使用道具 举报

Rank: 4

积分
1960
帖子
1075
精华
6
UID
17579
性别
保密

魔方理论探索者 论坛建设奖 六年元老

3#
发表于 2011-2-9 12:16:11 |只看该作者
这一层要完成stage1。
Enjoy cubing
Enjoy coding.
我喜欢的公式 U D F2 B2 U' D'

使用道具 举报

Rank: 4

积分
1960
帖子
1075
精华
6
UID
17579
性别
保密

魔方理论探索者 论坛建设奖 六年元老

4#
发表于 2011-2-9 12:18:00 |只看该作者
这一层将要完成stage2。
Enjoy cubing
Enjoy coding.
我喜欢的公式 U D F2 B2 U' D'

使用道具 举报

Rank: 4

积分
1960
帖子
1075
精华
6
UID
17579
性别
保密

魔方理论探索者 论坛建设奖 六年元老

5#
发表于 2011-2-9 12:20:24 |只看该作者
这一层要完成stage3
Enjoy cubing
Enjoy coding.
我喜欢的公式 U D F2 B2 U' D'

使用道具 举报

Rank: 4

积分
1960
帖子
1075
精华
6
UID
17579
性别
保密

魔方理论探索者 论坛建设奖 六年元老

6#
发表于 2011-2-9 12:21:54 |只看该作者
这一层要完成stage4
Enjoy cubing
Enjoy coding.
我喜欢的公式 U D F2 B2 U' D'

使用道具 举报

Rank: 4

积分
1960
帖子
1075
精华
6
UID
17579
性别
保密

魔方理论探索者 论坛建设奖 六年元老

7#
发表于 2011-2-9 12:23:32 |只看该作者
这一层把1234粘和起来。
欢迎支持
Enjoy cubing
Enjoy coding.
我喜欢的公式 U D F2 B2 U' D'

使用道具 举报

透魔

天空之城

Rank: 6Rank: 6

积分
6311
帖子
5891
精华
0
UID
36773

爱心大使 六年元老 十二年元老 十年元老

8#
发表于 2011-2-9 13:14:29 |只看该作者
不太明白,等代码出来了。。。。
继续SUB15中~~

使用道具 举报

Rank: 1

积分
145
帖子
145
精华
0
UID
82906
性别
9#
发表于 2011-2-9 13:51:07 |只看该作者
等结果出来………………

使用道具 举报

Rank: 6Rank: 6

积分
5072
帖子
5235
精华
0
UID
1279640

六年元老

10#
发表于 2011-2-9 13:58:37 |只看该作者
我慢慢的等结果出来。
ss三代普通版计时器批发
http://qiquwutoys.taobao.com/

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

Archiver|手机版|魔方吧·中文魔方俱乐部

GMT+8, 2024-11-24 08:00

Powered by Discuz! X2

© 2001-2011 Comsenz Inc.

回顶部