Yeon's 개발블로그

지식을 전파하는 개발자가 되고싶습니다.

백트래킹 4

[c++] 백준 15652: N과 M(4)

1) 문제 자연수 N과 M이 주어졌을 때, 아래 조건을 만족하는 길이가 M인 수열을 모두 구하는 프로그램을 작성하시오. 1부터 N까지 자연수 중에서 M개를 고른 수열 같은 수를 여러 번 골라도 된다. 고른 수열은 비내림차순이어야 한다. 길이가 K인 수열 A가 A1 ≤ A2 ≤ ... ≤ AK-1 ≤ AK를 만족하면, 비내림차순이라고 한다. 2) 입력 첫째 줄에 자연수 N과 M이 주어진다. (1 ≤ M ≤ N ≤ 8) 3) 출력 한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해야 한다. 4) 해결방법 전체적인 코드 구조는 백준 15649번의 N과 M 두번째 문제와 비슷하..

Algorithms/BFS DFS 2021.04.30

[c++] 백준 15651: N과 M(3)

1) 문제 자연수 N과 M이 주어졌을 때, 아래 조건을 만족하는 길이가 M인 수열을 모두 구하는 프로그램을 작성하시오. 1부터 N까지 자연수 중에서 M개를 고른 수열 같은 수를 여러 번 골라도 된다. 2) 입력 첫째 줄에 자연수 N과 M이 주어진다. (1 ≤ M ≤ N ≤ 8) 3) 출력 한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해야 한다. 4) 해결방법 전체적인 코드 구조는 백준 15649번의 N과 M 첫번째 문제와 비슷하다. 아직 첫번째 문제를 풀지 않았다면, 그 문제부터 푸는 것을 추천한다. 2021.04.30 - [백준 문제풀이/Backtracking] -..

Algorithms/BFS DFS 2021.04.30

[c++] 백준 15650: N과 M(2)

1) 문제 자연수 N과 M이 주어졌을 때, 아래 조건을 만족하는 길이가 M인 수열을 모두 구하는 프로그램을 작성하시오. 1부터 N까지 자연수 중에서 중복 없이 M개를 고른 수열 고른 수열은 오름차순이어야 한다. 2) 입력 첫째 줄에 자연수 N과 M이 주어진다. (1 ≤ M ≤ N ≤ 8) 3) 출력 한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해야 한다. 4) 해결방법 전체적인 코드 구조는 백준 15649번의 N과 M 첫번째 문제와 비슷하다. 아직 첫번째 문제를 풀지 않았다면, 그 문제부터 푸는 것을 추천한다. 2021.04.30 - [백준 문제풀이/Backtrack..

Algorithms/BFS DFS 2021.04.30

[c++] 백준 15649: N과 M

1) 문제 자연수 N과 M이 주어졌을 때, 아래 조건을 만족하는 길이가 M인 수열을 모두 구하는 프로그램을 작성하시오. 1부터 N까지 자연수 중에서 중복 없이 M개를 고른 수열 2) 입력 첫째 줄에 자연수 N과 M이 주어진다. (1 ≤ M ≤ N ≤ 8) 3) 출력 한 줄에 하나씩 문제의 조건을 만족하는 수열을 출력한다. 중복되는 수열을 여러 번 출력하면 안되며, 각 수열은 공백으로 구분해서 출력해야 한다. 수열은 사전 순으로 증가하는 순서로 출력해야 한다. 4) 해결방법 DFS와 backtracking을 이용하여 푸는 문제이다. n개의 숫자를 'DFS를 통해 완전탐색'하되, 만약 m개의 숫자가 선정되었으면, 'backtracking을 이용하여 그 전의 성공단계'로 돌아와야한다. arr 배열에 m개의 숫..

Algorithms/BFS DFS 2021.04.30