Post

leetcode(리트코드)5월22일 challenge51-N Queens

leetcode(리트코드)5월22일 challenge51-N Queens

leetcode May 22일 - N Queens 문제입니다.

1. 문제

https://leetcode.com/problems/n-queens/


2. Input , Output


3. 분류 및 난이도

Hard 난이도입니다.
5월 21일자 챌린지 문제입니다.


4. 문제 해석

  • 유명한 N Queens 문제입니다.
  • 대각선으로 겹치지 않게 병사들을 놓을 때 놓을 수 있는 경우의 수를 리턴합니다.
  • 대학교 수업에서 배운 것이 있어서 코드를 가져다 썼습니다.(이해는 잘 못함.)

5. code

python

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
class Solution:
    
    
    def solveNQueens(self, n: int) -> List[List[str]]:
        # 너무 깊게 재귀를 하지 않도록 제한을 걸어둡니다.
        def promising(i,col):
            k = 0
            switch = True
            while k < i and switch == True :
                if col[i] == col[k] or abs(col[i] - col[k]) == i -k :
                    switch = False
                k+=1
            return switch
        def queens(n,i,col,res): 
            if promising(i,col) : 
                if i == n-1 :
                    size = len(res)
                    res.append([])
                    for j in range(len(col)):
                        resstr = ""
                        find = col[j]
                        for k in range(len(col)):
                            if k ==find :
                                resstr+="Q"
                            else :
                                resstr+="."
                        res[size].append(resstr)
                else:
                    for j in range(0,n):
                        col[i+1] = j
                        queens(n,i+1,col,res)
        col = n *[0]
        res = []
        queens(n,-1,col,res)
        return res        

        

6. 결과 및 후기, 개선점

필요시 c++로 풀어드립니다.

This post is licensed under CC BY 4.0 by the author.