250x250
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
- 인공지능
- 그래프 이론
- MySQL
- BFS
- Python
- SIFT
- machine learning
- IN
- edge detection
- MinHeap
- 자료구조
- C++
- 강화학습
- exists
- TD
- DP
- image processing
- classification
- dfs
- 백준
- canny edge detection
- dynamic programming
- clustering
- Reinforcement Learning
- sklearn
- 머신러닝
- Mask Processing
- opencv
- AlexNet
- 딥러닝
Archives
- Today
- Total
JINWOOJUNG
[ 정렬 - 24174 ] 알고리즘 수업 - 힙 정렬 2(C++) 본문
728x90
반응형
문제
접근법
https://jinwoo-jung.tistory.com/56
지난 힙 정렬 1에서 설명한 Heap과 해당 코드의 내용으로 접근법에 대한 설명한 생략한다.
이번 문제는 교환 횟수에 따라서, 해당 교환까지 진행한 전체 Tree의 정렬 상태를 출력하는 문제이다.
이전에 언급 한 것처럼, s32_N Index는 Sorting() 과정에서 줄어든다. 따라서 전체 트리의 길이를 처음에 받아올 때, 전역변수로 하여 s32_Num에 저장한 후, 특정 교환이 진행 시 1부터 s32_Num까지 for문을 돌면서 전체 Tree의 정렬 상태를 출력하도록 하였다.
힙 정렬 1을 완벽히 이해했다면,,어렵지 않을 것이다.
정답
#include<iostream>
using namespace std;
void heapify(int32_t ars32_A[], int32_t s32_K, int32_t s32_N);
void heapsort(int32_t ars32_A[], int32_t s32_N);
void build_mean_heap(int32_t ars32_A[], int32_t s32_N);
int32_t s32_Cnt = 0, s32_Kmax, s32_Num, ars32_A[500001];
bool flag = true;
int main()
{
int32_t s32_I;
ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
cin >> s32_Num >> s32_Kmax;
for (s32_I = 1; s32_I <= s32_Num; s32_I++)
{
cin >> ars32_A[s32_I];
}
heapsort(ars32_A, s32_Num);
if (s32_Cnt < s32_Kmax)
{
cout << -1;
}
return 0;
}
void build_mean_heap(int32_t ars32_A[], int32_t s32_N)
{
int32_t s32_I;
for (s32_I = s32_N / 2; s32_I > 0; s32_I--)
{
heapify(ars32_A, s32_I, s32_N);
}
}
void heapsort(int32_t ars32_A[], int32_t s32_N)
{
int32_t s32_I;
build_mean_heap(ars32_A, s32_N);
for (s32_I = s32_N ; s32_I > 1; s32_I--)
{
if (flag)
{
int32_t s32_Tmp = ars32_A[1];
ars32_A[1] = ars32_A[s32_I];
ars32_A[s32_I] = s32_Tmp;
s32_Cnt += 1;
if (s32_Cnt == s32_Kmax)
{
for (s32_I = 1; s32_I <= s32_Num; s32_I++)
{
cout << ars32_A[s32_I] << " ";
}
cout << endl;
return;
}
heapify(ars32_A, 1, s32_I - 1);
}
else
return;
}
}
void heapify(int32_t ars32_A[], int32_t s32_K, int32_t s32_N)
{
int32_t s32_Left = s32_K * 2;
int32_t s32_Right = s32_K * 2 + 1;
int32_t s32_Smaller;
if (s32_Right <= s32_N)
{
if (ars32_A[s32_Left] < ars32_A[s32_Right])
{
s32_Smaller = s32_Left;
}
else
{
s32_Smaller = s32_Right;
}
}
else if (s32_Left <= s32_N)
{
s32_Smaller = s32_Left;
}
else
return;
if (ars32_A[s32_Smaller] < ars32_A[s32_K])
{
int32_t s32_I;
int32_t s32_Tmp = ars32_A[s32_Smaller];
ars32_A[s32_Smaller] = ars32_A[s32_K];
ars32_A[s32_K] = s32_Tmp;
s32_Cnt += 1;
if (s32_Cnt == s32_Kmax)
{
for (s32_I = 1; s32_I <= s32_Num; s32_I++)
{
cout << ars32_A[s32_I] << " ";
}
cout << endl;
flag = false;
return;
}
heapify(ars32_A, s32_Smaller, s32_N);
}
}
728x90
반응형
'백준' 카테고리의 다른 글
[ DP - 12865 ] 평범한 배낭(C++) (0) | 2024.05.20 |
---|---|
[ DP-11049 ] 행렬 곱셈 순서(C++) (0) | 2024.05.19 |
[ 정렬 - 24173 ] 알고리즘 수업 - 힙 정렬 1(C++) (2) | 2024.04.03 |
[ 트리 - 1991 ] 트리 순회(C++) (0) | 2024.04.03 |
[ DP - 17626 ] Four Squares (0) | 2024.04.02 |