bubble sorting, insert sorting, select sorting, implementing

juwon·2022년 6월 21일
0

Algorithms

목록 보기
1/7

버블 정렬, 삽입 정렬, 선택 정렬 구현

import java.util.Arrays;

public class Main {
    // 오름차순 기준 정렬 알고리즘

    // 버블 정렬
    public static void bubbleSort(int[] arr) {
//      1.
        for (int i = 1; i < arr.length - 1; i++) {
            for (int j = 0; j < arr.length - i; j++) {
                if (arr[j] > arr[j + 1]){
                    int tmp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j+1] = tmp;
                }
            }

        }

//      2.  
        for (int i = arr.length - 1; i > 0 ; i--) {
            for (int j = 0; j < i; j++) {
                if (arr[j] > arr[j+1]){
                    int tmp = arr[j];
                    arr[j] = arr[j+1];
                    arr[j+1] = tmp;
                }
            }

        }

        }

    
    // 삽입 정렬
    public static void insertionSort(int[] arr) {
        for (int i = 1; i < arr.length; i++) {
            for (int j = i; j > 0; j--) {
                if (arr[j] < arr[j - 1]){
                    int tmp = arr[j];
                    arr[j] = arr[j-1];
                    arr[j-1] = tmp;
                } else {
                    break;
                }

            }

        }
    }

    // 선택 정렬
    private static void selectionSort(int[] arr) {
//        1. 최소 값을 찾아 앞 쪽부터 교환하는 방식
        for (int i = 0; i < arr.length - 1; i++) {
            int min = i;
            for (int j = i + 1; j < arr.length; j++) {
                if (arr[j] < arr[min]){
                    min = j;
                }

            }
            int tmp = arr[i];
            arr[i] = arr[min];
            arr[min] = tmp;
        }

//        2. 최대 값을 찾아 뒤 쪽부터 교환하는 방식
        for (int i = arr.length - 1; i > 0; i--) {
            int max = i;
            for (int j = i - 1; j >= 0 ; j--) {
                if (arr[j] > arr[max]){
                    max = j;
                }

            }
            int tmp = arr[i];
            arr[i] = arr[max];
            arr[max] = tmp;

        }

    }
//출력
버블 정렬: [1, 2, 3, 4, 5, 7]
삽입 정렬: [1, 2, 3, 4, 5, 7]
선택 정렬: [1, 2, 3, 4, 5, 7]

0개의 댓글