Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 두원사이의정수쌍
- Lv2
- JS
- 지도 여러개
- 우박수열정적분
- solved.ac플래티넘
- [pccp 기출문제]
- 5강클로저
- pccp기출문제
- div2개
- 정렬
- 스택
- 코어자바스크립트
- 타겟넘버
- 이중지도
- React.StrictMode
- 알고리즘문제풀이
- Lv3
- 2023카카오블라인드코테
- JS스터디
- 백준알고리즘
- 백준 알고리즘
- 알고리즘 문제풀이
- 과제진행하기
- solved.ac골드
- 최소스패닝트리
- 프로그래머스
- DP
- 비트마스크
- c++
Archives
- Today
- Total
호지
[백준 알고리즘] 1766번 문제집 문제풀이 c++ 본문
1~n개의 문제 중 앞 번호의 문제를 먼저 푸는게 더 좋다.
m개의 선행되어야할 문제 조건이 주어지는데
이 조건을 만족하면서 앞 번호의 문제를 우선적으로 풀 때 결과를 출력하면 된다.
위상정렬을 priority_queue로 구현하면 된다.
cnt배열에 해당 문제에 선행조건이 몇개있는지 저장한다.
order 벡터에 해당 문제가 선행조건인 문제번호를 저장한다.
priority_queue은 번호가 낮을 수록 우선순위를 갖도록
priority_queue<int, vector<int>, greater<int>>로 선언한다.
cnt배열이 0일때, 즉 선행조건이 없는 경우 q에 push한다.
그 후 q가 비어있지 않을 때까지 q의 top을 pop하면서
해당 문제가 선행조건인 문제의 cnt를 감소시키고
cnt값이 0일때의 문제 번호를 p에 push한다.
#include <iostream>
#include <queue>
#include <vector>
using namespace std;
int cnt[32001];
vector<vector<int>> order(32001);
int main(){
int n, m;
cin >> n >> m;
int a,b;
for(int i=0; i<m; i++){
cin >> a >> b;
cnt[b]++;
order[a].push_back(b);
}
priority_queue<int,vector<int>, greater<int>> q;
for(int i=1; i<=n; i++){
if(cnt[i] == 0){
q.push(i);
cnt[i] = -1;
}
}
while(!q.empty()){
int x = q.top();
cout << x << " ";
q.pop();
for(int i=0; i<order[x].size(); i++){
if(--cnt[order[x][i]] == 0){
q.push(order[x][i]);
cnt[order[x][i]] = -1;
}
}
}
return 0;
}
'알고리즘 > 백준' 카테고리의 다른 글
[백준 알고리즘] 1806번 부분합 (0) | 2022.05.04 |
---|---|
[백준 알고리즘] 1799번 비숍 문제풀이 c++ (0) | 2022.05.04 |
[백준 알고리즘] 1647번 도시 분할 계획 (0) | 2022.05.02 |
[백준 알고리즘] 1644번 소수의 연속 합 (0) | 2022.05.01 |
[백준 알고리즘] 1562번 계단 수 c++ (0) | 2022.04.30 |
Comments