RadarURL

논문
2012.07.23 03:56

알고리즘 복잡도(complexity)

조회 수 4852 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

알고리즘 복잡도(complexity)

 알고리즘의 복잡도는 n개의 자료가 사용하여 알고리즘을 작성하였을 경우 알고리즘을 수행하는데 걸리는 시간을 n에 비례하여 표현한다.
기본적으로 n개의 자료를 가지고있는 자료 알고리즘의 실행시간이 n개의 자료에 비례한다는 의미에서 O(n)을 사용한다.


알고리즘 효율 관계 (n)

상수 > log2n > n > nlog2n > n² > n³ > 2ⁿ


O(c) 상수 효율

c는 상수이다. 즉, n의 자리에 변수가아니라 상수가 들어가는 경우이다.
이 경우 복잡도는 항상 x축에 수평이므로, 알고리즘의 수행에 걸리는 시간이 자료 집합의 크기에 상관없으며, 그 수행 시간은 항상 일정하다.


O(log₂n) 로그 효율

밑수가 2인 로그함수의 복잡도는 자료집합의 크기가 두배가 될때마다 수행시간은 1씩 증가한다.
로그기반 알고리즘은 자료의 크기와 독립적인 O(c)를 제외하고, 자료의 크기에 의존적인 알고리즘들 중에서 가장 효율적이다.


O(n) 선형 효율

자료집합의 크기가 증가함에 따라 일정한 비율로 완만하게 증가한다.


O(nlog₂n) 선형 지수 효율

 정렬 알고리즘이 목표로하는 최소한의 복잡도이다.
잘 짜여진 트리라던가, 이분 검색, 퀵 정렬과 같은 알고리즘에서 볼 수 있다.



O(n²) 제곱 효율

자료집합이 증가함에 따라 그 수행시간이 급격히 증가하는 경우이다.
대표적으로 for문 안에 for문이 내포된 경우


O(n³) 세제곱 효율

 제곱 효율보다 수행시간이 오래걸리므로 성능이 좋지 못한 복잡도이다.

대표적인 알고리즘으로는 Floyd 알고리즘이 있으며 Floyd 알고리즘과 같이 for문이 3겹으로 사용되거나 하는 경우이다.

덧붙여서 Floyd 알고리즘은 좋지못한 효율을 보임에도 불구하고 간단한 코딩방식 덕분에 많은 사람들에게 애용되고 있다 (...)


O(2ⁿ) 지수 효율

자료의 개수가 1개 증가할 때마다 수행시간이 2의 지수배로 증가하는 매우 비효율적인 경우의 복잡도이다.

 

출처 : http://blog.naver.com/PostView.nhn?blogId=noasaint&logNo=80053308964

?

공부 게시판

공부에 도움되는 글을 올려주세요.

  1. [공지] 공부 게시판 입니다.

    Date2003.08.18 By처누 Views931844
    read more
  2. 홍콩 보내주다를 뜻하는 영어 표현 한가지를 노래를 통해 배워보자

    Date2025.10.28 Category연애 ByJaeSoo Views20
    Read More
  3. 향수 잔향 기간별 구분

    Date2025.10.28 Category생활 ByJaeSoo Views18
    Read More
  4. Question about Korean - What does 홍콩을 보내다 mean?

    Date2025.10.28 Category생활 ByJaeSoo Views17
    Read More
  5. 리눅스 서버 설치 중 에러 "Failed to find a suitable stage1 device"

    Date2025.10.03 Category유닉스/리눅스 ByJaeSoo Views46
    Read More
  6. Linux 11 . Linux 설치 시 lvm 수동설정

    Date2025.10.03 Category유닉스/리눅스 ByJaeSoo Views37
    Read More
  7. [Rocky Linux] 누구나 쉽게 따라하는 Rocky Linux 9.0 OS 다운로드 및 설치 방법~!!

    Date2025.10.03 Category유닉스/리눅스 ByJaeSoo Views63
    Read More
  8. Linux/Rocky Linux Rocky Linux : Composer 설치

    Date2025.09.29 Category유닉스/리눅스 ByJaeSoo Views55
    Read More
  9. [Rocky Linux] 록키 리눅스 최신 업데이트 적용 방법

    Date2025.09.29 Category유닉스/리눅스 ByJaeSoo Views52
    Read More
  10. rocky linux 커널 업데이트

    Date2025.09.29 Category유닉스/리눅스 ByJaeSoo Views47
    Read More
  11. [Windows] OWASP ZAP 사용법

    Date2025.09.29 Category웹서버,WAS ByJaeSoo Views62
    Read More
  12. [웹 취약점] 웹서버 디렉토리 리스팅 방지

    Date2025.09.29 Category웹서버,WAS ByJaeSoo Views69
    Read More
  13. Clonezilla(클론질라) 백업파일 하드디스크로 복구 방법

    Date2025.09.28 Category유닉스/리눅스 ByJaeSoo Views54
    Read More
  14. 클론질라 사용 방법 - OS 이미지 백업 CloneZilla

    Date2025.09.28 Category유닉스/리눅스 ByJaeSoo Views74
    Read More
  15. [Linux / Rocky] FTP 접속 관련 설정 실습 예제

    Date2025.09.23 Category유닉스/리눅스 ByJaeSoo Views96
    Read More
  16. Could not reliably determine the server's fully qualified domain name

    Date2025.09.23 Category유닉스/리눅스 ByJaeSoo Views95
    Read More
  17. [아파치] 아파치 웹서버에 .htaccess 파일 설정하는 방법

    Date2025.09.23 Category유닉스/리눅스 ByJaeSoo Views70
    Read More
  18. [Linux] Apache web server의 rewrite module 사용하기 [출처] [Linux] Apache web server의 rewrite module 사용하기|작성자 g00dmoney

    Date2025.09.23 Category유닉스/리눅스 ByJaeSoo Views67
    Read More
  19. 록키 리눅스 9.1에서 apache, mysql, PHP 설치

    Date2025.09.23 Category유닉스/리눅스 ByJaeSoo Views78
    Read More
  20. [권한문제] 라이믹스 Fatal error: Uncaught Rhymix\Framework\Exception: Cannot write template cache file

    Date2025.09.23 Category유닉스/리눅스 ByJaeSoo Views70
    Read More
  21. 라이믹스 php 에러 표시

    Date2025.09.23 Category유닉스/리눅스 ByJaeSoo Views58
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 126 Next
/ 126


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

숭실대 컴퓨터 통신연구실 (서창진)

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

아스가르드 좋은사람/나쁜사람

JServer.kr

제이서버 메타블로그

재수 티스토리


즐겨찾기 (강의, 커뮤니티)

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너