성장일기

내가 보려고 정리하는 공부기록

백트래킹 3

[백준] 9663: N-Queen (백트래킹) - JAVA

https://www.acmicpc.net/problem/9663  # 문제N-Queen 문제는 크기가 N × N인 체스판 위에 퀸 N개를 서로 공격할 수 없게 놓는 문제이다.N이 주어졌을 때, 퀸을 놓는 방법의 수를 구하는 프로그램을 작성하시오. # 예제입력 :  첫째 줄에 N이 주어진다. (1 ≤ N 8 출력 :  첫째 줄에 퀸 N개를 서로 공격할 수 없게 놓는 경우의 수를 출력한다.92 # 필요개념우선 어떤 경우에 퀸이 공격을 할 수 있게 되는지 알고있어야 한다. 퀸은 다음과 같은 조건에서 공격할 수 있다.같은 열에 있는 경우같은 대각선상에 있는 경우즉, 문제가 원하는 것은 같은 열에 있지 않고, 동시에 같은 대각선상에 있지 않는 경우의 수를 출력하라는 뜻이다.  이를 파악하기 위해서는 퀸이 놓인 ..

[백준] 15666 : N과 M (12) (백트래킹) - JAVA

solved ac (실버2)https://www.acmicpc.net/problem/15666 # 문제N개의 자연수와 자연수 M이 주어졌을 때, 아래 조건을 만족하는 길이가 M인 수열을 모두 구하는 프로그램을 작성하시오.N개의 자연수 중에서 M개를 고른 수열같은 수를 여러 번 골라도 된다.고른 수열은 비내림차순이어야 한다.길이가 K인 수열 A가 A1 ≤ A2 ≤ ... ≤ AK-1 ≤ AK를 만족하면, 비내림차순이라고 한다. # 예제입력 : 첫째 줄에 N과 M이 주어진다. (1 ≤ M ≤ N ≤ 8)둘째 줄에 N개의 수가 주어진다. 입력으로 주어지는 수는 10,000보다 작거나 같은 자연수이다.4 29 7 9 1 출력 : 한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 ..

[백준] 15663 : N과 M(9) (백트래킹) - JAVA

solved ac (실버2)https://www.acmicpc.net/problem/15663 # 문제N개의 자연수와 자연수 M이 주어졌을 때, 아래 조건을 만족하는 길이가 M인 수열을 모두 구하는 프로그램을 작성하시오.N개의 자연수 중에서 M개를 고른 수열 # 예제입력 : 첫째 줄에 N과 M이 주어진다. (1 ≤ M ≤ N ≤ 8)둘째 줄에 N개의 수가 주어진다. 입력으로 주어지는 수는 10,000보다 작거나 같은 자연수이다.3 14 4 2 출력 : 한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해야 한다.24 # 필요개념 해당 문제는 DFS를 이용한 백트래킹으로 풀..

728x90