f this phase
for( i=0; icout/cout
}
没专业学过c++,计算机程序知识,可能有些说法不精确,不适宜,但应该佷直白。另外程序佷巧妙,足可见算法之妙,且程序佷简洁,见Jaap Scherphuis功力深厚。我一开始,也想写个用Thistlethwaite's algorithm魔方程序,但见了他的,我打算解释他的程序,供大家参考。再次申明,佩服之至。感谢Jaap Scherphuis。大家也享受吧。
所有资料包括介绍Thistlethwaite的方法,我存储在http://www.doczj.com/doc/35769b87a0116c175f0e48b3.html/share/link?shareid=405906&uk=1898872422
旋转函数
UF DF UB DB UR DR UL DL FR FL BR BL UFR UBL DFL DBR DLB DRF URB ULF
0A 1B 2C 3D 4E 5F 6G 7H 8I 9J 10K 11L 12M 13N 140 15P 16Q 17R 18S 19T
这是位置编排方式
POS【20】 各个位置所含的方块
ori【20】 各个位置所含方块的朝向
val【20】 各个位置所含方块朝向总数 角3 棱2
*perm="AIBJTMROCLDKSNQPEKFIMSPRGJHLNTOQAGCEMTNSBFDHORPQ" 以八个为一组分别代表FBRLUD面 以此来为旋转面上各位置的方向、所含块提供准确变化方式
void domove(int m){ m从0到5 分别代表fbrlud面的旋转 顺时针
char *p&#