[백준] 15665번: N과 M (11) C++로 풀어보기

2023. 7. 31. 00:26·Algorithm/Baekjoon(C++)

15665번 설명

생각

앞선 N과 M 문제처럼 백트래킹을 사용하면 된다.

 

백트래킹(backtracking)이란? : 해를 찾는 도중 해가 아니어서 막히면, 되돌아가서 다시 해를 찾아가는 기법을 말합니다. 최적화 문제와 결정 문제를 푸는 방법이 됩니다.

출처 : https://chanhuiseok.github.io/posts/algo-23/

 

알고리즘 - 백트래킹(Backtracking)의 정의 및 예시문제

이번에 살펴볼 개념은 백트래킹에 관한 내용입니다.

chanhuiseok.github.io

 

만약 백트래킹에 대해서 더 자세히 배우고 싶다면 바킹독님의 강의를 듣는 것을 추천한다.

바킹독 백트래킹 강의

 

 

다른 점은 같은 수를 여러 번 골라도 된다는 점이다.

그렇다면 수가 사용되었는 지 검사하는 부분은 빼도 된다.

 

그리고 예제 입력 1을 보면 두 번째 줄에 '4 4 2' 이렇게 입력되었는데, 4가 두 개가 있어서 출력에 문제가 생긴다.

이 문제를 풀 때 벡터를 이용할 예정인데, 벡터에서 중복된 수를 지우는 방법을 찾아봐야겠다. 

 

코드
#include <bits/stdc++.h>
using namespace std;

int n, m;
vector <int> v;
int arr[10];

void func(int k) { // 현재 k개까지 수를 택했음.
    if (k == m) { // m개를 모두 택했으면
        for (int i = 0; i < m; i++)
            cout << arr[i] << ' '; // arr에 기록해둔 수를 출력
        cout << '\n';
        return;
    }

    for (auto it = v.begin(); it != v.end(); it++) { // 백트래킹을 사용한다.
        arr[k] = *it; // 배열에 현재 iterator가 가리키는 수를 넣는다. 
        func(k + 1);  // 한 단계 더 들어간다.
    }
}

int main(void) {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cin >> n >> m;
    
    while (n--) { // 수를 입력받아 벡터에 넣는다.
        int x;
        cin >> x;
        v.push_back(x);
    }
    
    sort(v.begin(), v.end()); // 오름차순으로 정렬
    v.erase(unique(v.begin(), v.end()), v.end()); // 중복된 수 제거

    func(0); // func(0) 실행
}

일단 벡터 안에 입력된 중복된 수를 없애려면 sort를 이용하여 정렬을 하고 unique와 erase를 이용해서 중복된 수를 삭제를 하면 된다.

(밑에 링크를 참고하면 더 자세히 알 수 있다.)

https://kkaeruk.tistory.com/19

 

[C++ STL : vector] 벡터 중복원소 제거

안녕하세요 ~ 깨륵입니다 '▽'/ 벡터 세번째 시간이네요ㅎㅎ 이번에는 벡터에서 중복원소를 제거하는 간단한 코드를 가져왔습니다! 한번 보러 가실까요? 혹시 벡터 기본 사용법이 익숙치 않다면

kkaeruk.tistory.com

 

 

결과

15665번 결과

 

저작자표시 비영리 변경금지 (새창열림)

'Algorithm > Baekjoon(C++)' 카테고리의 다른 글

[백준] 10814번: 나이순 정렬 C++로 풀어보기  (1) 2023.08.06
[백준] 10989번: 수 정렬하기 3 C++로 풀어보기  (1) 2023.08.05
[백준] 2630번: 색종이 만들기 C++로 풀어보기  (0) 2023.07.30
[백준] 7562번: 나이트의 이동 C++로 풀어보기  (1) 2023.07.28
[백준] 11050번: 이항 계수 1 C++로 풀어보기  (1) 2023.07.27
'Algorithm/Baekjoon(C++)' 카테고리의 다른 글
  • [백준] 10814번: 나이순 정렬 C++로 풀어보기
  • [백준] 10989번: 수 정렬하기 3 C++로 풀어보기
  • [백준] 2630번: 색종이 만들기 C++로 풀어보기
  • [백준] 7562번: 나이트의 이동 C++로 풀어보기
퀵차분
퀵차분
Web Developer 🥐
QC's DevlogWeb Developer 🥐
  • 퀵차분
    QC's Devlog
    퀵차분
  • 전체
    오늘
    어제
    • 분류 전체보기 (168)
      • Frontend (28)
        • HTML, CSS (7)
        • Javascript (3)
        • React (11)
        • Typescript (2)
        • Next.js (4)
      • Node.js (3)
      • Fedify (3)
      • Study (40)
        • Modern JS Deep Dive (13)
        • SQL (1)
        • Network (1)
        • 프롬프트 엔지니어링 (4)
        • 인공지능 (9)
        • 시스템프로그래밍 (11)
        • 선형대수학 (1)
      • Intern (4)
      • KUIT (20)
      • Algorithm (48)
        • Baekjoon(C++) (26)
        • Programmers(JavaScript) (22)
      • 우아한테크코스(프리코스) (4)
      • Project (7)
        • PROlog (4)
        • Nomadcoder (2)
      • 생각 (4)
      • Event (7)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    typescript
    프롬프트 엔지니어링
    백준
    리액트
    HTML
    javascript
    알고리즘
    next.js
    음악추천
    시스템프로그래밍
    오블완
    KUIT
    인공지능
    자바스크립트
    타입스크립트
    프로그래머스 자바스크립트
    프론트엔드
    티스토리챌린지
    프로그래머스
    react
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
퀵차분
[백준] 15665번: N과 M (11) C++로 풀어보기

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.