[백준] Baekjoon Online Judge
문제
오늘도 서준이는 삽입 정렬 수업 조교를 하고 있다. 아빠가 수업한 내용을 학생들이 잘 이해했는지 문제를 통해서 확인해보자.
N개의 서로 다른 양의 정수가 저장된 배열 A가 있다. 삽입 정렬로 배열 A를 오름차순 정렬할 경우 정렬 과정에서 배열 A가 배열 B와 같은 경우가 발생하는지 확인해 보자. 초기 상태 배열 A도 정렬 과정에서 발생 가능한 경우로 생각하자.
크기가 N인 배열에 대한 삽입 정렬 의사 코드는 다음과 같다.
insertion_sort(A[1..N]) { # A[1..N]을 오름차순 정렬한다.
for i <- 2 to N {
loc = i - 1;
newItem = A[i];
# 이 지점에서 A[1..i-1]은 이미 정렬되어 있는 상태
while (1 <= loc and newItem < A[loc]) {
A[loc + 1] <- A[loc];
loc--;
}
if (loc + 1 != i) then A[loc + 1] = newItem;
}
}
입력
첫째 줄에 배열 A, B의 크기 N(5 ≤ N ≤ 10,000)이 주어진다.
다음 줄에 서로 다른 배열 A의 원소 A1, A2, ..., AN이 주어진다. (1 ≤ Ai ≤ 109)
다음 줄에 배열 B의 원소 B1, B2, ..., BN이 주어진다. (1 ≤ Bi ≤ 109)
출력
삽입 정렬로 배열 A를 오름차순 정렬하는 과정에서 배열 A가 배열 B와 같은 경우가 발생하면 1, 아니면 0을 출력한다.
예제 입력 | 예제 출력 |
5 4 5 1 3 2 1 3 4 5 5 |
1 |
5 4 5 1 3 2 1 3 2 4 5 |
0 |
풀이
#include <iostream>
#include <vector>
using namespace std;
int insertion_sort(int N);
vector <int> A(10001);
vector <int> B(10001);
// 삽입 정렬
int insertion_sort(int N) {
//A[]을 오름차순 정렬한다.
for (int i = 1; i < N; i++) {
int loc;
int newItem = A[i];
// 이 지점에서 A[1..i - 1]은 이미 정렬되어 있는 상태
for (loc = i - 1; loc >= 0 && newItem < A[loc]; loc--) {
A[loc + 1] = A[loc];
// 배열 A가 배열 B와 같은 경우
if (A == B) return 1;
}
if (loc + 1 != i) {
A[loc + 1] = newItem;
// 배열 A가 배열 B와 같은 경우
if (A == B) return 1;
}
}
return 0;
}
int main() {
int N; // 배열의 크기 N
scanf("%d", &N);
for (int i = 0; i < N; i++)
scanf("%d", &A[i]);
for (int i = 0; i < N; i++)
scanf("%d", &B[i]);
// 출력
printf("%d\n", insertion_sort(N));
return 0;
}
편하게 배열을 비교하기 위해서 vector을 사용해서 배열 A와 배열 B를 만들었다. 숫자를 삽입하는 부분마다 두 배열이 같은 지 확인하는 if문 코드를 넣은 뒤 서로 같다면 1을 return하게끔 했다. 만약 정렬이 모두 끝났는데도 해당 if문에 걸리지 않는다면 0을 return하게 된다. 그리고 return 받은 값을 출력했다.
'백준 > C++' 카테고리의 다른 글
[Baekjoon/C++] 24061번 - 알고리즘 수업 - 병합 정렬 2 (0) | 2023.02.21 |
---|---|
[Baekjoon/C++] 24060번 - 알고리즘 수업 - 병합 정렬 1 (0) | 2023.02.20 |
[Baekjoon/C++] 24052번 - 알고리즘 수업 - 삽입 정렬 2 (0) | 2023.02.16 |
[Baekjoon/C++] 24051번 - 알고리즘 수업 - 삽입 정렬 1 (0) | 2023.02.15 |
[Baekjoon/C++] 23900번 - 알고리즘 수업 - 선택 정렬 6 (0) | 2023.02.13 |