Contents

Develop
2014.06.24 09:43

알고리즘 성능분석

조회 수 2961 댓글 0
Atachment
첨부 '1'
?

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
알고리즘의 성능을 분석할때 중요한 키워드 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
번호 분류 제목 글쓴이 날짜 조회 수
1137 Develop [ios] VIN Scanner (VIN barcode) 스캐너 file hooni 2017.09.16 644
1136 Develop [ios] SBCampanion App 초안 file hooni 2015.09.16 651
1135 Develop [ios] NSNotificationCenter 초간단 사용 예~ ㅋㄷ hooni 2015.06.26 654
1134 Database [mysql] MySql DB/테이블 사이즈 확인을 위한 쿼리 hooni 2019.11.22 656
1133 Develop [ios] WWDC 2015 샘플 소스 코드 통합파일 hooni 2015.07.20 657
1132 Database [mysql] MySQL 데이터베이스 추가 및 사용자 추가 hooni 2019.11.22 661
1131 Develop [ios] Touch ID 적용 샘플 코드 (예제) file hooni 2015.02.23 663
1130 Develop [ios] 여러 버전의 Xcode 사용하기 hooni 2022.05.28 664
1129 Develop [swift] 실행시간 측정하기 hooni 2021.09.14 672
1128 Develop Aspect Oriented Programming in Objective-C hooni 2015.05.18 674
1127 Develop [js] Text 값을 클립보드에 복사하기 hooni 2020.10.10 675
1126 Develop 정리할 자료. file hooni 2015.07.02 677
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 98 Next
/ 98