루빅스 큐브의 총 4 차원 꼬임 계산 방법

Aug 18 2020

나는 Rubik의 큐브를 해결하기 위해 Thistlewaite의 알고리즘을 구현하는 작업을하고 있으며, 이제 tetrad twists 문제에 직면 해 있습니다. 이 답변 덕분에 나는 그것이 무엇인지, 그리고 그들이 단계 3에서 상태의 양을 줄이는 방법을 이해하지만, 내가 가진 문제는 큐브의 총 4 트위스트를 상태에서만 계산하는 방법을 찾는 것입니다.

이 알고리즘을 구현하는 방식은 폭 우선 검색이 아니므로 여기 와 여기 에서 찾은 더 강력한 조건을 사용하여 3 단계를 완료했는지 알 수 없습니다. 내가하는 방식은 룩업 테이블을 미리 계산하고 특정 상태를 해결하기 위해 알아 내기 위해 조사하는 것입니다. 따라서 여러 단계 3 상태를 구분하는 데 필요한 정보를 완전히 특성화해야합니다. 코너 4 개, 모서리 슬라이스 및 패리티가 이미 완료되었습니다. 마지막으로 필요한 것은 상태 (또는 이와 동등한 정보)의 4 개 트위스트를 표현하는 방법입니다. 가장 좋은 방법은 단순히 0, 1 또는 2 사이의 값을 제공하고이를 사용하여 전체 비틀림을 설명하는 것입니다.

제 질문이 명확하기를 바라며, 그렇지 않다면 의견을 통해 질문을 해주시면 더 자세히 설명해 드리겠습니다.

답변

3 JaapScherphuis Aug 18 2020 at 16:18

코너 조각의 현재 위치에서 직접이 정보를 추출하는 것은 다소 어렵습니다. 가장 쉬운 방법은 (가장자리 부분을 무시하면서) 절반 만 돌려서 모서리 부분을 실제로 해결하고 얼마나 멀리 있는지 확인하는 것입니다.

지금은 코너 조각이 올바른 4 차원 궤도 {UFR, UBL, DFL, DBR} 및 {UFL, UBR, DFR, DBL}에 이미 있다고 가정합니다. 당신은 하나의 테트라 드 조각을 정말 쉽게 풀 수 있습니다. 각 조각에 대해 반 바퀴 이하로, 최대 3 개의 움직임까지입니다. 예를 들어 {D2, B2, R2} 중 최대 하나를 사용하여 DBR을 풀고, {F2, L2} 중 최대 하나를 사용하여 DFL을 풀고, 필요한 경우 마지막으로 {U2}를 사용하여 UBL을 풀면 UFR도 해결됩니다.

그런 다음 이동 시퀀스 {F2 L2 F2 U2, U2 F2 U2 L2, L2 U2 L2 F2} 중 하나를 사용하여 DBL과 같은 두 번째 테트라 드의 한 조각을 풉니 다. 이러한 이동 시퀀스는 두 번째 테트라 드의 4 개 조각에 대해 이중 스왑을 수행하며 첫 번째 테트라 드를 고정 할 수있는 유일한 순열입니다.

이로 인해 {UFL, UBR, DFR}의 세 가지 미해결 조각이 남습니다. 3! = 6 순열 중 하나 일 수 있습니다. 이 6 가지 가능성은 순열 패리티와 결합 된 4 차 트위스트를 나타내므로이 순열을 0에서 5까지의 숫자에 매핑하면 순열 패리티와 4 차 트위스트를 모두 단일 숫자로 인코딩 한 것입니다.

Thistlethwaite 알고리즘의 경우 알고리즘의 세 번째 단계의 임의 위치를 ​​인코딩하고 싶을 것입니다. 이것은 일관된 방식으로 수행되어야합니다. 즉, 동일한 이동 순서에 의해 두 개의 다른 위치가 네 번째 단계로 이동하면 (즉, 이동 순서를 해당 위치에 적용한 후 둘 다 반 회전만으로 해결할 수있게 됨) 이 두 위치는 3 단계에 대해 동일한 인코딩을 가져야합니다.

아마도 프로그램은 특정 고정 된 순서로 큐브의 모서리 위치를 나열합니다. 예를 들어
UFR , UFL, UBL , UBR, DFR, DFL , DBL, DBR 순서로 위치를 나타내는 길이 8 배열이있을 수 있습니다 .
배열의 인덱스 0, 2, 5, 7에있는 4 개의 위치 중 하나를 나타내는 위치를 굵게 표시했습니다. 프로그램에서 다른 순서 지정 규칙을 선택했을 수 있지만 방법은 동일합니다.

이제 임의의 3 단계 큐브 위치가 있다고 가정합니다. 예를 들어
UBR, UBL , DBR , DFR, DFL , UFR , UFL, DBL 과 같이 8 개 모서리의 임의 순열이 있습니다.
조각을 두 개의 tetrad로 분리하는 간단하고 일관된 방법은
UBL , DBR , DFL , UFR
UBR, DFR, UFL, DBL 의 상대적 순서를 변경하지 않고 문자 그대로 두 가지 유형의 조각을 분리하는 것 입니다.
그런 다음 스토리지 어레이에 순서대로 올바른 4 차원 위치 세트에 넣습니다. 따라서 첫 번째 세트는 인덱스 0,2,5,7에, 다른 세트는 인덱스 1,3,4,6에 있습니다.
UBL , UBR, DBR, DFR, UFL, DFL , DBL, UFR .
이제 처음에 설명한 해결 기술을 적용하여 4 자 트위스트 및 패리티 위치를 일관되게 인코딩 할 수 있습니다.
위는 큐브를 표현하기 위해 표준화 된 단일 방법을 사용하고 여기에 이동을 적용한다고 가정합니다. 대신이 위치의 단순화 된 표현으로 4 개 조각의 두 개의 개별 목록을 유지하고 트위스트 + 패리티 인코딩을 추출하기 위해이를 풀 때 직접 변경하는 것이 좋습니다.

이 오래된 큐브 프로그래밍 경연 대회 에서 일부 프로그램을 살펴볼 수 있지만, 명료 함이 아닌 간결함을 위해 작성 되었기 때문에 크게 도움이 될지는 모르겠습니다.