본문 바로가기
스도쿠문제 풀이/AM7 스도쿠풀이

[문제풀이] AM7 스도쿠 2007년 07월 06일 Normal

by 김프로 2007. 7. 6.
 
    2       1 9 8
  4     9     3 6
3               4
        7 3   4  
      1   6      
  8   2 5        
8               3
9 3     2     5  
1 6 4       9    

※ 풀이과정 입니다. (셀 좌표는 [컬럼,로우])

L01 - Naked Single : [3,1]셀 "2"값과 관련된 로우, 컬럼, 블럭에서 "2"값 제거
L01 - Naked Single : [7,1]셀 "1"값과 관련된 로우, 컬럼, 블럭에서 "1"값 제거
L01 - Naked Single : [8,1]셀 "9"값과 관련된 로우, 컬럼, 블럭에서 "9"값 제거
L01 - Naked Single : [9,1]셀 "8"값과 관련된 로우, 컬럼, 블럭에서 "8"값 제거
L01 - Naked Single : [2,2]셀 "4"값과 관련된 로우, 컬럼, 블럭에서 "4"값 제거
L01 - Naked Single : [5,2]셀 "9"값과 관련된 로우, 컬럼, 블럭에서 "9"값 제거
L01 - Naked Single : [8,2]셀 "3"값과 관련된 로우, 컬럼, 블럭에서 "3"값 제거
L01 - Naked Single : [9,2]셀 "6"값과 관련된 로우, 컬럼, 블럭에서 "6"값 제거
L01 - Naked Single : [1,3]셀 "3"값과 관련된 로우, 컬럼, 블럭에서 "3"값 제거
L01 - Naked Single : [9,3]셀 "4"값과 관련된 로우, 컬럼, 블럭에서 "4"값 제거
L01 - Naked Single : [5,4]셀 "7"값과 관련된 로우, 컬럼, 블럭에서 "7"값 제거
L01 - Naked Single : [6,4]셀 "3"값과 관련된 로우, 컬럼, 블럭에서 "3"값 제거
L01 - Naked Single : [8,4]셀 "4"값과 관련된 로우, 컬럼, 블럭에서 "4"값 제거
L01 - Naked Single : [4,5]셀 "1"값과 관련된 로우, 컬럼, 블럭에서 "1"값 제거
L01 - Naked Single : [6,5]셀 "6"값과 관련된 로우, 컬럼, 블럭에서 "6"값 제거
L01 - Naked Single : [2,6]셀 "8"값과 관련된 로우, 컬럼, 블럭에서 "8"값 제거
L01 - Naked Single : [4,6]셀 "2"값과 관련된 로우, 컬럼, 블럭에서 "2"값 제거
L01 - Naked Single : [5,6]셀 "5"값과 관련된 로우, 컬럼, 블럭에서 "5"값 제거
L01 - Naked Single : [1,7]셀 "8"값과 관련된 로우, 컬럼, 블럭에서 "8"값 제거
L01 - Naked Single : [9,7]셀 "3"값과 관련된 로우, 컬럼, 블럭에서 "3"값 제거
L01 - Naked Single : [1,8]셀 "9"값과 관련된 로우, 컬럼, 블럭에서 "9"값 제거
L01 - Naked Single : [2,8]셀 "3"값과 관련된 로우, 컬럼, 블럭에서 "3"값 제거
L01 - Naked Single : [5,8]셀 "2"값과 관련된 로우, 컬럼, 블럭에서 "2"값 제거
L01 - Naked Single : [8,8]셀 "5"값과 관련된 로우, 컬럼, 블럭에서 "5"값 제거
L01 - Naked Single : [1,9]셀 "1"값과 관련된 로우, 컬럼, 블럭에서 "1"값 제거
L01 - Naked Single : [2,9]셀 "6"값과 관련된 로우, 컬럼, 블럭에서 "6"값 제거
L01 - Naked Single : [3,9]셀 "4"값과 관련된 로우, 컬럼, 블럭에서 "4"값 제거
L01 - Naked Single : [7,9]셀 "9"값과 관련된 로우, 컬럼, 블럭에서 "9"값 제거
L01 - Naked Single : [3,8]셀 "7"값과 관련된 로우, 컬럼, 블럭에서 "7"값 제거
L01 - Naked Single : [9,8]셀 "1"값과 관련된 로우, 컬럼, 블럭에서 "1"값 제거
L01 - Naked Single : [3,7]셀 "5"값과 관련된 로우, 컬럼, 블럭에서 "5"값 제거
L01 - Naked Single : [2,7]셀 "2"값과 관련된 로우, 컬럼, 블럭에서 "2"값 제거

-- 현재 빈칸에 올수있는 모든 후보들을 찾은 상태입니다. --
567 57 2 34567 346 457 1 9 8
57 4 18 578 9 12578 257 3 6
3 1579 1689 5678 168 12578 257 27 4
256 159 169 89 7 3 2568 4 259
2457 579 39 1 48 6 23578 278 2579
467 8 1369 2 5 49 367 167 79
8 2 5 4679 146 1479 467 67 3
9 3 7 468 2 48 468 5 1
1 6 4 3578 38 578 9 278 27

L02 - Hidden Single : [8,6]셀 "1"값은 컬럼8 에서 유니크 값, 관련된 로우, 컬럼, 블럭에서 "1"값 제거
L02 - Hidden Single : [8,7]셀 "6"값은 컬럼8 에서 유니크 값, 관련된 로우, 컬럼, 블럭에서 "6"값 제거
L02 - Hidden Single : [4,8]셀 "6"값은 로우8 에서 유니크 값, 관련된 로우, 컬럼, 블럭에서 "6"값 제거

567 57 2 3457 346 457 1 9 8
57 4 18 578 9 12578 257 3 6
3 1579 1689 578 168 12578 257 27 4
256 159 169 89 7 3 2568 4 259
2457 579 39 1 48 6 23578 278 2579
467 8 369 2 5 49 367 1 79
8 2 5 479 14 1479 47 6 3
9 3 7 6 2 48 48 5 1
1 6 4 3578 38 578 9 278 27

L03 - Naked Pair : 블럭1 {2,4}번째 셀 "57"값은 Subset 패턴2, 나머지셀에서 "57"값 제거

6 57 2 3457 346 457 1 9 8
57 4 18 578 9 12578 257 3 6
3 19 1689 578 168 12578 257 27 4
256 159 169 89 7 3 2568 4 259
2457 579 39 1 48 6 23578 278 2579
467 8 369 2 5 49 367 1 79
8 2 5 479 14 1479 47 6 3
9 3 7 6 2 48 48 5 1
1 6 4 3578 38 578 9 278 27

L01 - Naked Single : [1,1]셀 "6"값과 관련된 로우, 컬럼, 블럭에서 "6"값 제거
L02 - Hidden Single : [5,3]셀 "6"값은 로우3 에서 유니크 값, 관련된 로우, 컬럼, 블럭에서 "6"값 제거
L02 - Hidden Single : [5,7]셀 "1"값은 컬럼5 에서 유니크 값, 관련된 로우, 컬럼, 블럭에서 "1"값 제거

6 57 2 3457 34 457 1 9 8
57 4 18 578 9 12578 257 3 6
3 19 189 578 6 12578 257 27 4
25 159 169 89 7 3 2568 4 259
2457 579 39 1 48 6 23578 278 2579
47 8 369 2 5 49 367 1 79
8 2 5 479 1 479 47 6 3
9 3 7 6 2 48 48 5 1
1 6 4 3578 38 578 9 278 27

L04 - InterSection Lock : 컬럼9 vs 블럭6, 블럭6의 "5"값은 반드시 컬럼9 내에 위치해야 함

6 57 2 3457 34 457 1 9 8
57 4 18 578 9 12578 257 3 6
3 19 189 578 6 12578 257 27 4
25 159 169 89 7 3 268 4 259
2457 579 39 1 48 6 2378 278 2579
47 8 369 2 5 49 367 1 79
8 2 5 479 1 479 47 6 3
9 3 7 6 2 48 48 5 1
1 6 4 3578 38 578 9 278 27

L05 - Hidden Pair : 로우6 {3,7}번째 셀 "36"값은 Subset 패턴2, {3,7}번째 셀 "36"(이)가 아닌값 제거

6 57 2 3457 34 457 1 9 8
57 4 18 578 9 12578 257 3 6
3 19 189 578 6 12578 257 27 4
25 159 169 89 7 3 268 4 259
2457 579 39 1 48 6 2378 278 2579
47 8 36 2 5 49 36 1 79
8 2 5 479 1 479 47 6 3
9 3 7 6 2 48 48 5 1
1 6 4 3578 38 578 9 278 27

L05 - Hidden Pair : 컬럼6 {2,3}번째 셀 "12"값은 Subset 패턴2, {2,3}번째 셀 "12"(이)가 아닌값 제거

6 57 2 3457 34 457 1 9 8
57 4 18 578 9 12 257 3 6
3 19 189 578 6 12 257 27 4
25 159 169 89 7 3 268 4 259
2457 579 39 1 48 6 2378 278 2579
47 8 36 2 5 49 36 1 79
8 2 5 479 1 479 47 6 3
9 3 7 6 2 48 48 5 1
1 6 4 3578 38 578 9 278 27

L04 - InterSection Lock : 컬럼6 vs 블럭8, 블럭8의 "8"값은 반드시 컬럼6 내에 위치해야 함

6 57 2 3457 34 457 1 9 8
57 4 18 578 9 12 257 3 6
3 19 189 578 6 12 257 27 4
25 159 169 89 7 3 268 4 259
2457 579 39 1 48 6 2378 278 2579
47 8 36 2 5 49 36 1 79
8 2 5 479 1 479 47 6 3
9 3 7 6 2 48 48 5 1
1 6 4 357 3 578 9 278 27

L01 - Naked Single : [5,9]셀 "3"값과 관련된 로우, 컬럼, 블럭에서 "3"값 제거
L01 - Naked Single : [5,1]셀 "4"값과 관련된 로우, 컬럼, 블럭에서 "4"값 제거
L01 - Naked Single : [5,5]셀 "8"값과 관련된 로우, 컬럼, 블럭에서 "8"값 제거
L01 - Naked Single : [4,4]셀 "9"값과 관련된 로우, 컬럼, 블럭에서 "9"값 제거
L01 - Naked Single : [6,6]셀 "4"값과 관련된 로우, 컬럼, 블럭에서 "4"값 제거
L01 - Naked Single : [6,8]셀 "8"값과 관련된 로우, 컬럼, 블럭에서 "8"값 제거
L01 - Naked Single : [7,8]셀 "4"값과 관련된 로우, 컬럼, 블럭에서 "4"값 제거
L01 - Naked Single : [1,6]셀 "7"값과 관련된 로우, 컬럼, 블럭에서 "7"값 제거
L01 - Naked Single : [9,6]셀 "9"값과 관련된 로우, 컬럼, 블럭에서 "9"값 제거
L01 - Naked Single : [7,7]셀 "7"값과 관련된 로우, 컬럼, 블럭에서 "7"값 제거
L01 - Naked Single : [9,9]셀 "2"값과 관련된 로우, 컬럼, 블럭에서 "2"값 제거
L01 - Naked Single : [1,2]셀 "5"값과 관련된 로우, 컬럼, 블럭에서 "5"값 제거
L01 - Naked Single : [7,2]셀 "2"값과 관련된 로우, 컬럼, 블럭에서 "2"값 제거
L01 - Naked Single : [7,3]셀 "5"값과 관련된 로우, 컬럼, 블럭에서 "5"값 제거
L01 - Naked Single : [8,3]셀 "7"값과 관련된 로우, 컬럼, 블럭에서 "7"값 제거
L01 - Naked Single : [1,4]셀 "2"값과 관련된 로우, 컬럼, 블럭에서 "2"값 제거
L01 - Naked Single : [9,4]셀 "5"값과 관련된 로우, 컬럼, 블럭에서 "5"값 제거
L01 - Naked Single : [7,5]셀 "3"값과 관련된 로우, 컬럼, 블럭에서 "3"값 제거
L01 - Naked Single : [7,6]셀 "6"값과 관련된 로우, 컬럼, 블럭에서 "6"값 제거
L01 - Naked Single : [2,1]셀 "7"값과 관련된 로우, 컬럼, 블럭에서 "7"값 제거
L01 - Naked Single : [6,1]셀 "5"값과 관련된 로우, 컬럼, 블럭에서 "5"값 제거
L01 - Naked Single : [6,2]셀 "1"값과 관련된 로우, 컬럼, 블럭에서 "1"값 제거
L01 - Naked Single : [4,3]셀 "8"값과 관련된 로우, 컬럼, 블럭에서 "8"값 제거
L01 - Naked Single : [2,4]셀 "1"값과 관련된 로우, 컬럼, 블럭에서 "1"값 제거
L01 - Naked Single : [3,5]셀 "9"값과 관련된 로우, 컬럼, 블럭에서 "9"값 제거
L01 - Naked Single : [6,9]셀 "7"값과 관련된 로우, 컬럼, 블럭에서 "7"값 제거

6 7 2 3 4 5 1 9 8
5 4 8 7 9 1 2 3 6
3 9 1 8 6 2 5 7 4
2 1 6 9 7 3 8 4 5
4 5 9 1 8 6 3 2 7
7 8 3 2 5 4 6 1 9
8 2 5 4 1 9 7 6 3
9 3 7 6 2 8 4 5 1
1 6 4 5 3 7 9 8 2

Logic 사용횟수
L01 - Naked Single 59회
L02 - Hidden Single 5회
L03 - Naked Pair 1회
L04 - InterSection Lock 2회
L05 - Hidden Pair 2회

소요시간 : 0분 0.187초

Logic 순서
L01 - Naked Single
L02 - Hidden Single
L03 - Naked Pair
L04 - InterSection Lock
L05 - Hidden Pair
L06 - Naked Triple
L07 - Hidden Triple
L08 - Naked Quad
L09 - Hidden Quad
L10 - X-Wing
L11 - Sword-Fish
L12 - Jelly-Fish
Z99 - Substitution
Z99 - RollbackSudoku

현재 모든로직이 완성되지않아 "L12"번 까지의 풀이법으로 문제를 풀수없는경우 Z99 - Substitution(대입법)을 이용합니다.
L12 - Jelly-Fish 풀이법보다 상위 풀이법은 현재 작업중입니다.

Sudoku K ver3.11.694 by keetekee