본문 바로가기
728x90

선택 정렬4

[11399] ATM (JAVA) # 문제 설명 인하은행에는 ATM이 1대밖에 없다. 지금 이 ATM앞에 N명의 사람들이 줄을 서있다. 사람은 1번부터 N번까지 번호가 매겨져 있으며, i번 사람이 돈을 인출하는데 걸리는 시간은 Pi분이다. 사람들이 줄을 서는 순서에 따라서, 돈을 인출하는데 필요한 시간의 합이 달라지게 된다. 예를 들어, 총 5명이 있고, P1 = 3, P2 = 1, P3 = 4, P4 = 3, P5 = 2 인 경우를 생각해보자. [1, 2, 3, 4, 5] 순서로 줄을 선다면, 1번 사람은 3분만에 돈을 뽑을 수 있다. 2번 사람은 1번 사람이 돈을 뽑을 때 까지 기다려야 하기 때문에, 3+1 = 4분이 걸리게 된다. 3번 사람은 1번, 2번 사람이 돈을 뽑을 때까지 기다려야 하기 때문에, 총 3+1+4 = 8분이 필요.. 2024. 3. 26.
Day-5 선택 정렬 1. 선택 정렬 대상에서 가장 크거나 작은 데이터를 찾아가 선택을 반복하면서 정렬하는 방식이다. 구현이 복잡하다. 시간 복잡도가 O(n²)으로 느리다. 최솟값 또는 최댓값을 찾고, 가장 앞에 있는 데이터와 swap하여 정렬한다. 2. 선택 정렬 과정 남은 정렬 부분에서 최솟값 또는 최댓값 찾기 (min = 1) 남은 정렬 부분에서 가장 앞에 있는 데이터와 찾은 데이터를 swap (1, 3 swap) 가장 앞에 있는 데이터의 위치를 변경하여 남은 정렬 부분 범위를 축소 (i++) 남은 정렬 부분이 없을 때까지 반복 3. 예제 문제 [1427] 소트인사이드 (JAVA) # 문제 설명 배열을 정렬하는 것은 쉽다. 수가 주어지면, 그 수의 각 자리수를 내림차순으로 정렬해보자. 입력 첫째 줄에 정렬하려고 하는 수.. 2024. 3. 23.
[23881] 알고리즘 수업 - 선택 정렬 1 (JAVA) # 문제 설명 오늘도 서준이는 선택 정렬 수업 조교를 하고 있다. 아빠가 수업한 내용을 학생들이 잘 이해했는지 문제를 통해서 확인해보자. N개의 서로 다른 양의 정수가 저장된 배열 A가 있다. 선택 정렬로 배열 A를 오름차순 정렬할 경우 K 번째 교환되는 수를 구해서 우리 서준이를 도와주자. 크기가 N인 배열에 대한 선택 정렬 의사 코드는 다음과 같다. selection_sort(A[1..N]) { # A[1..N]을 오름차순 정렬한다. for last 0; i--) { int maxIdx = i; for (int j = 0; j < i; j++) { if (A[maxIdx] < A[j]) { maxIdx = j; } } if (maxIdx != i) { cnt++; if (cnt == K) { Syst.. 2024. 3. 23.
[1427] 소트인사이드 (JAVA) # 문제 설명 배열을 정렬하는 것은 쉽다. 수가 주어지면, 그 수의 각 자리수를 내림차순으로 정렬해보자. 입력 첫째 줄에 정렬하려고 하는 수 N이 주어진다. N은 1,000,000,000보다 작거나 같은 자연수이다. 출력 첫째 줄에 자리수를 내림차순으로 정렬한 수를 출력한다. # 정답 코드 import java.io.*; import java.util.*; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); StringTokenizer st = new StringTokenizer(br.. 2024. 3. 23.
728x90