배푸니까

[백준 / JAVA] 15649. N과 M (1) 본문

백준

[백준 / JAVA] 15649. N과 M (1)

baefrica 2023. 10. 22. 22:52
반응형

https://www.acmicpc.net/problem/15649

 

15649번: N과 M (1)

한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해

www.acmicpc.net

 


💻 풀이 결과

💯 최종 코드

import java.util.Scanner;

public class Main {
	static int N;
	static int M;
	static int[] arr;
	static boolean[] visited;

	// 백트래킹
	public static void backTracking(int cnt) { // 현재 cnt 만큼 선택했다.
		if (cnt == M) { // M 개를 모두 선택했으면
			for (int i = 0; i < arr.length; i++) {
				System.out.print(arr[i] + " "); // arr 에 저장해놓은 수들을 출력
			}
			System.out.println();

			return;
		}

		for (int i = 1; i <= N; i++) {
			// 패스 조건
			if (visited[i]) { // 방문했으면 패스
				continue;
			}

			// cnt 번째 수는 i 이다.
			arr[cnt] = i;
			// 방문 체크
			visited[i] = true;
			// 백트래킹
			backTracking(cnt + 1);
			// 방문 체크 풀기
			visited[i] = false;
		}
	}

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);

		N = sc.nextInt();
		M = sc.nextInt();
		arr = new int[M];
		visited = new boolean[N + 1];

		backTracking(0);
	}
}

💬 풀이 과정

  • 결과를 저장할 배열과 방문처리할 배열을 생성한다.
  • 백트래킹을 통해 방문한 숫자는 패스하고 cnt를 하나씩 늘려가며 수열을 만든다.

💡 깨달은 점

1. 백트래킹

  • 백트래킹을 통해 재귀를 호출하는 연습을 했다.
  • N과 M 시리즈를 통해 백트래킹을 좀 더 연습을 해야 한다.
반응형

'백준' 카테고리의 다른 글

[백준 / JAVA] 1629. 곱셈  (0) 2023.10.22
[백준 / JAVA] 2146. 다리 만들기  (0) 2023.10.16
[백준 / JAVA] 13549. 숨바꼭질3  (0) 2023.09.03
[백준 / JAVA] 2573. 빙산  (0) 2023.08.31
[백준 / JAVA] 2206. 벽 부수고 이동하기  (0) 2023.08.30