Contents

Develop
2014.06.24 09:43

알고리즘 성능분석

Views 2963 Comment 0
Atachment
Attachment '1'
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
알고리즘의 성능을 분석할때 중요한 키워드 3가지가 있다.
 
1. 시간복잡도(Time Complexity)
시간복잡도는 알고리즘을 수행시 걸리는 시간에 대한 분석결과를 말한다.
 
2. 공간 복잡도(Space Complexity)
공간복잡도는 알고리즘을 수행시 메모리 사용량에 대한 분석결과를 말한다.
 
3. 빅-오 (Big-O)
시간복잡도를 나타낼 때 함수에서 가장 영향력이 큰부분을 말한다.
 
이 중 시간복잡도와 공간복잡도에 대해서 먼저 설명하겠다.
 
시간과 메모리 사용량을 적절이 판단하면서 알고리즘을 채택하여야 하는데
알고리즘을 채택하는데 있어서 객관적인 자료로 사용할 수 있기때문이다.
 
그럼 시간복잡도는 어떻게 측정을 할까?
프로그램이 시작되서 끝날때까지의 시간을 측정하는 방법은
자료의 양에따라 처리값이 다르기 때문에 알고리즘의 성능을 예측할수가 없다.
그래서 아래와 같이 측정한다.
 
1 . 연산의 횟수를 센다.
2 . 처리해야 할 데이터 수 n에 대한 함수T(n)을 나타낸다.

big_o.png

이렇게 측정을하면 어떤 알고리즘을 사용해야하는지에 대한 지표가 될 수 있다.

[출처] http://blog.naver.com/rkdgml6332/220038985752

?

List of Articles
No. Category Subject Author Date Views
229 Develop [c++] 인라인 함수 설명과 예제.. file hooni 2013.04.23 6633
228 Develop [c] 웅지학원 NAT를 소스코드로.. file hooni 2013.04.23 6611
227 Develop [c] 간단한 점 이동 샘플 소스코드 hooni 2013.04.23 6541
226 Develop [c] 민수형 소스(도메인소켓포함) file hooni 2013.04.23 6522
225 Develop [js] 새로고침(refresh)방법과 다른 페이지 바꾸기.. hooni 2003.04.23 6521
224 Develop [c] 네트워크 보안 프로그래밍 과제 (Server,Agent,Client) file hooni 2013.04.23 6472
223 Develop [js] 윤동이가 만든 영어 학습(?) 프로그램 file hooni 2013.04.23 6462
222 Develop [c] 메세지 프로그램 (Server - Agent - Client) file hooni 2013.04.23 6457
221 Develop [php] 정규표현식 간단히 정리 hooni 2013.04.23 6453
220 Develop [doc] C언어 문법 설명서 file hooni 2013.04.23 6437
219 Develop [java] 채팅창 처럼2.. swing.. file hooni 2013.04.23 6421
218 Develop [c] 다중연결 서버 만들기 #3 - poll() 사용 file hooni 2013.04.23 6340
Board Pagination Prev 1 ... 47 48 49 50 51 52 53 54 55 56 ... 71 Next
/ 71