C
2005.08.10 09:55

선택정렬 Selection Sort

조회 수 34281 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

+ - Up Down Comment Print Files
?

단축키

Prev이전 문서

Next다음 문서

+ - Up Down Comment Print Files


이 첨부 파일에 있는 건 일반적인 함수의 형태이다. (int형 뿐 아니라 모든 형태의 자료형을 비교할 수 있도록 만든 것이다)
자료 배열의 선두 번지인 base,
자료의 개수 nelem,
레코드의 크기 width,
키값의 비교를 하는 함수 포인터 fcmp 를 뜻한다.
fcmp 함수는
int intcmp(const void *a, const void *b) 등을 뜻한다.


■ 선택 정렬 개념

실제 프로그래밍에 많이 사용되는 간단한 정렬 방법으로 첫번째 키 부터 기준키로 설정하며, 기준키로 설정된 값과 두번째 위치, 세 번째 위치, … n 번째위치의 값과 비교하면서 정렬
가장 작은 인자를 찾아서 제일 앞에 놓고, 이 다음 작은 인자를 찾아 앞에 놓는 방법을 반복
예 : 열 장의 명함을 놓고 이름을 가나다순으로 다시 정리하는 방법
    - 가장 먼저 오는 이름을 가진 명함을 찾아서 제일 앞에 놓음
    - 그 다음 올 수 있는 명함을 두 번째에 놓고... 하는 작업을 반복하여 열 개의 명함들을 정리
■ 선택 정렬 단계(오름차순의 경우)

입력 레코드에서 가장 작은 키 값을 갖는 레코드를 찾아 첫 번째 위치에 있는 레코드와 교환
첫 번째 위치한 레코드를 제외한 n-1개의 레코드중에서 가장 작은 키 값을 갖는 레코드를 찾아 두 번째 위치에 있는 레코드와 교환
이러한 수행 과정을 반복 수행하면 최종적으로 n-1번째 레코드와 n번째 레코드 중 키 값이 작은 레코드를 n-1번째에 위치시켜 정렬을 종료

■ 주어진 배열 A 가 n개의 데이터를 가질 때 선택정렬의 수행 단계

배열 A 에서 가장 작은 값을 갖는 데이터를 찾는다.
그 데이터를 배열의 맨 처음 데이터인 A[0]와 교환한다.
두 번째 작은 값을 갖는 데이터를 찾아서 배열의 두 번째 데이터인 A[1]과 교환한다.
배열의 전체 데이터가 정렬될 때까지 이 과정을 반복한다.



■ 선택 정렬 알고리즘

----------------------------------------------
void SelectionSort(int A[], int n)
{
    int i, j, min;
    for (i=0; i < n-1; i++)
    {
        min = i;
        for (j=i+1; j < n; j++)
            if (A[j] < A[min])  min = j;
        temp = A[min];
        A[min] = A[i];
        A[i] = temp;
    }
}
-----------------------------------------------


■ 성능

기본 연산 : 최소값을 갖는 데이터를 찾기 위한 비교연산과
                 필요하면 데이터들의 위치를 교환하여주는 교환연산
첫 번째 단계 : 주어진 n개의 데이터 중에서 최소값을 찾기 위하여 (n-1)번의 비교가 수행
두 번째 단계 : 나머지 (n-1)개의 데이터 중에서의 최소값을 찾기 위한 (n-2)번의 비교가 수행
선택정렬 알고리즘을 이용하여 n개의 데이터를 정렬하려면 약 n2/2 번의 비교를 수행
==> O(n2)
선택정렬 알고리즘에서는 매 단계마다 최대 한번씩의 교환이 일어나므로 전체적으로 볼 때
(n-1)번의 교환이 수행
선택정렬 알고리즘은 주어진 배열 안에서 데이터들의 이동을 최소화하려는 목적으로 만들어짐
데이터의 양이 적을 때 아주 좋은 성능을 나타냄

Dreamy의 코드 스크랩

내가 모으고 내가 보는

List of Articles
번호 분류 제목 날짜 조회 수 추천 수
41 일반 자주 사용하는 아주 유용한 파워포인트 단축키 [Useful Short-cut for PowerPoint] 2013.04.01 20077 0
40 일반 장치관리자 실행 명령어 2013.08.05 14871 0
39 일반 적분 해주는 함수 예제 file 2005.08.05 41496 0
38 일반 전기적 스펙에 관한 용어, 약자 정리 2020.02.24 5033 0
37 Pi 전압 분배(분배 저항)로 병렬 저항 계산하기 2017.07.25 9808 0
36 업무 전자저널 이용안내 secret 2016.08.29 0 0
35 LINUX 접속한 사용자 확인 w 명령어 2013.05.02 13252 0
34 C# 정규식 사용하기 2012.11.27 16483 0
33 일반 정규식 요약 2013.01.23 15554 0
32 일반 정규식 요약 프린트 file 2014.04.21 10766 0
31 C 정규식 테스트 사이트 2012.09.20 17521 0
30 Python 줄 바꿈 없이 출력하는 방법 2019.03.30 6985 0
29 Pi 칩 저항 사이즈표, 사이즈변환, 와트, 오차표 2019.01.11 10633 0
28 Android 카톡 SDK 의 안드로이드 기기 unique ID 얻기 방법 2015.01.02 15769 0
27 Python 커맨드 라인에서 컬러로 출력하기 termcolor 2014.06.27 10660 0
목록
Board Pagination ‹ Prev 1 ... 27 28 29 30 31 32 33 34 Next ›
/ 34

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

설치 취소

Designed by sketchbooks.co.kr / sketchbook5 board skin

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5