알고리즘/SWEA

SWEA D3 2806 NQueen

  • -
반응형

SWEA D3 2806 NQueen

 

 

문제링크

https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV7GKs06AU0DFAXB

 

SW Expert Academy

SW 프로그래밍 역량 강화에 도움이 되는 다양한 학습 컨텐츠를 확인하세요!

swexpertacademy.com

* 일단 문제를 정독 하고 1시간 이상 반드시 고민이 필요합니다.

 

동영상 설명

1시간 이상 고민 했지만 아이디어가 떠오르지 않는다면 동영상에서 약간의 힌트를 얻어봅시다.

 

소스 보기

동영상 설명을 보고도 전혀 구현이 안된다면 이건 연습 부족입니다.
소스를 보고 작성해 본 후 스스로 백지 상태에서 3번 작성해 볼 의지가 있다면 소스를 살짝 보세요.

더보기
package se.code.d3;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.StringReader;

/**
 * @author itsmeyjc
 * @since 2019. 3. 7.
 * @see https://swexpertacademy.com/main/code/problem/problemDetail.do?contestProbId=AV7GKs06AU0DFAXB
 * @mem 29,264 kb
 * @time 127 ms
 * @caution #backtracking, #dfs
 */
public class SWEA_D3_2806_NQueen {
    static StringBuilder output = new StringBuilder();

    static int T;
    static int N;
    static int[] columnOf;// 각 row를 index로 해당 row에서의 column 값을 저장할 배열
    static int answer;

    public static void main(String[] args) throws IOException {
        BufferedReader input = new BufferedReader(new InputStreamReader(System.in));
        input = new BufferedReader(new StringReader(src));

        T = Integer.parseInt(input.readLine());

        for (int t = 1; t <= T; t++) {
            N = Integer.parseInt(input.readLine());

            columnOf = new int[N];
            answer = 0;
            dfs(0);

            output.append("#").append(t).append(" ").append(answer).append("\n");
        }
        System.out.println(output);
    }

    static void dfs(int row) {
        if (row == N) {
            answer++;
            return;
        }
        for (int col = 0; col < N; col++) {
            columnOf[row] = col;
            // 방금 놓은 자리가 유망하다면 다음 가보기
            if (isPromising(row)) {
                dfs(row + 1);
            }
        }
    }

    static boolean isPromising(int currentRow) {
        for (int r = 0; r < currentRow; r++) {
            // 위쪽으로 혹시 같은 값 없나?
            if (columnOf[r] == columnOf[currentRow]) {
                return false;
            }
            // 오른쪽, 왼쪽 대각선으로 위쪽으로 가면서 같은 녀석 없나?
            if (Math.abs(r - currentRow) == Math.abs(columnOf[r] - columnOf[currentRow])) {
                return false;
            }
        }
        return true;
    }
    // END:

    static String src = "2\r\n" +
                        "1\r\n" +
                        "2";
}

 

반응형

'알고리즘 > SWEA' 카테고리의 다른 글

SWEA D4 7206 숫자게임  (0) 2020.05.23
SWEA 모의 5644 무선충전  (0) 2020.05.21
SWEA D5 4112 이상한 피라미드 탐험  (0) 2020.05.05
SWEA D4 1486 장훈이의 높은 선반  (0) 2020.05.04
SWEA 모의 1949 등산로 조성  (0) 2020.05.01
Contents

포스팅 주소를 복사했습니다

이 글이 도움이 되었다면 공감 부탁드립니다.