선택 정렬 : 가장 작은 값을 선택해서 교환한다.
코드
#include <iostream>
#include <algorithm>
using namespace std;
int main() {
ios_base::sync_with_stdio(false);
int N,tmp,key,cnt = 0;
int arr[100];
cin >> N;
for(int i = 0; i < N; i++){
cin >> arr[i];
}
for(int i = 0; i < N-1; i++){
key = i;
for(int j = key; j < N; j++){
if(arr[key] > arr[j]) key = j; //작은 값이 선택된다.
}
//선택된 작은 값과 교환한다
tmp = arr[key];
arr[key] = arr[i];
arr[i] = tmp;
}
for(int i = 1; i < N; i++){
if(arr[i-1] != arr[i]) cnt++; //어차피 정렬 돼어있으니까 이전값이랑 중복이 아니면 cnt해준다.
if(cnt == 3){
cout << arr[i];
break;
}
}
return 0;
}
https://www.inflearn.com/course/%EC%95%8C%EA%B3%A0%EB%A6%AC%EC%A6%98/dashboard
'기타등등 > 알고리즘 기록' 카테고리의 다른 글
[C++] 삽입정렬 - Least Recently Used(카카오캐시 변형) (0) | 2021.07.27 |
---|---|
[C++] 버블정렬 - Special Sort(구글 인터뷰) (0) | 2021.07.27 |
[C++]Jolly Jumper (0) | 2021.06.21 |
[C++] 연속부분 증가수열 (0) | 2021.06.21 |
[C++] 온도의 최대값 (0) | 2021.06.19 |