[BAEKJOON] 백준 23899: 알고리즘 수업 - 선택 정렬 5 (C#)

2024. 10. 30. 17:52IT/BaekJoon

문제 링크

https://www.acmicpc.net/problem/23899

 

 

문제

오늘도 서준이는 선택 정렬 수업 조교를 하고 있다. 아빠가 수업한 내용을 학생들이 잘 이해했는지 문제를 통해서 확인해보자.

N개의 서로 다른 양의 정수가 저장된 배열 A가 있다. 선택 정렬로 배열 A를 오름차순 정렬할 경우 정렬 과정에서 배열 A가 배열 B와 같은 경우가 발생하는지 확인해 보자. 초기 상태 배열 A도 정렬 과정에서 발생 가능한 경우로 생각하자.

크기가 N인 배열에 대한 선택 정렬 의사 코드는 다음과 같다.

selection_sort(A[1..N]) { # A[1..N]을 오름차순 정렬한다.
    for last <- N downto 2 {
        A[1..last]중 가장 큰 수 A[i]를 찾는다
        if (last != i) then A[last] <-> A[i]  # last와 i가 서로 다르면 A[last]와 A[i]를 교환
    }
}

 

 

입력

첫째 줄에 배열 A, B의 크기 N(5 ≤ N ≤ 10,000)이 주어진다.

다음 줄에 서로 다른 배열 A의 원소 A1, A2, ..., AN이 주어진다. (1 ≤ Ai ≤ 10^9)

다음 줄에 서로 다른 배열 B의 원소 B1, B2, ..., BN이 주어진다. (1 ≤ Bi ≤ 10^9)

 

 

출력

선택 정렬로 배열 A를 오름차순 정렬하는 과정에서 배열 A가 배열 B와 같은 경우가 발생하면 1, 아니면 0을 출력한다.

 

 

 

통과한 답안

namespace _23899
{
    internal class Program
    {
        static void Main(string[] args)
        {
            int N = int.Parse(Console.ReadLine());
            int[] A = Console.ReadLine().Split(' ').Select(int.Parse).ToArray();
            int[] B = Console.ReadLine().Split(' ').Select(int.Parse).ToArray();

            if (IsEqual(A, B))
            {
                Console.WriteLine(1);
                return;
            }
            else
            {
                SelSort(A, B);
            }
        }

        static void SelSort(int[] A, int[] B)
        {
            for (int last = A.Length - 1; last > 0; last--)
            {
                int maxIdx = last;
                for (int j = 0; j < last; j++)
                {
                    if (A[j] > A[maxIdx])
                    {
                        maxIdx = j;
                    }
                }

                if (last != maxIdx)
                {
                    int tmp = A[maxIdx];
                    A[maxIdx] = A[last];
                    A[last] = tmp;
                }

                if (IsEqual(A, B))
                {
                    Console.WriteLine(1);
                    return;
                }
            }

            Console.WriteLine(0);
        }

        static bool IsEqual(int[] A, int[] B)
        {
            for (int i = 0; i < A.Length; i++)
            {
                if (A[i] != B[i]) return false;
            }

            return true;
        }
    }
}

 

주어진 배열 A가 선택정렬을 수행하면서

배열 B와 같아지는 순간이 발생하는지 확인하는 문제이다.

선택정렬을 하는 메서드 SelSort와

두 배열이 같은지 확인하는 메서드 IsEqual를 구현하여 사용하였다.

 

IsEqual의 경우 배열의 각각의 원소를 순회하며

두 배열의 원소가 같은지 확인하도록 구현하였으며,

선택정렬의 경우에는 조건에서 큰 숫자를 먼저 맨 뒤로 보냈기 때문에

배열의 끝쪽부터 정렬하도록 구현하였다.

 

이 문제를 통해서 배열을 정렬하는 방법 중 하나인

선택정렬의 개념을 다시 확인할 수 있었으며,

두 배열이 같은지 확인하는 LINQ의 메서드 SequenceEqual을 찾아볼 수 있었다.

static bool IsEqual(int[] A, int[] B)
{
    return A.SequenceEqual(B);
}