RadarURL

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
시간 복잡도(알고리즘)
 

0. 들어가기 앞서서
 

자료구조와 알고리즘을 배울때 핵심은 공간과 시간 이용이다.
공간과 시간은 거의 항상 반비례하는 경향이있다.

시간복잡도: 어떤 알고리즘이 얼마나 걸리느냐(CPU사용량)
공간복잡도: 어떤 알고리즘이 메모리를 얼마나 쓰느냐(RAM사용량)



1.시간의 복잡도에 나타나는 수들 (맨날 까먹으니 웬만하면 외우자)


as_1-loudon23.gif



1(constant): 입력자료의 수에 관계 없이 일정한 실행 시간을 갖는 알고리즘


log N: 만약 입력 자료의 수에 따라 실행 시간이 이 log N 의 관계를 만족한다면 N이 증가함에 따라 실행시간이 조금씩 늘어난다. 이 유형은 주로 커다란 문제를 일정한 크기를 갖는 작은 문제로 쪼갤때 나타나는 유형이다.

N(Lonear): 입력 자료의 수에 따라 선형적으로 실행 시간이 걸리는 경우이다. 이는 입력 자료 각각에 일정 정도의 동일한 처리를 할때 나타나는 경우이다.

N logN : 이 유형은 커다란 문제를 독립적인 작은 문제로 쪼개어 각각에 대해 독립적으로 해결하고,나중에 다시 그것들을 하나로 모으는 경우에 나타난다. N이 두배로 늘어나면 실행 시간은 2배보다 약간 더 많이 늘어난다.

N²(quadratic): 이 유형은 이중루프내에서 입력 자료를 처리 하는 경우에 나타난다. N값이 큰값이 되면 실행 시간은 감당하지 못할 정도로 커지게 된다.

N³(Cubic): 이 유형은 앞의 유형과 비슷하게 입력 자료를 삼중 루프내에서 처리하는 경우에 나타난다.

2 : 입력자료의 수가 늘어남에 따라 급격히 실행 시간이 늘어난다. 이 유형은 흔하지는 않지만 가끔씩 알고리즘을 처음 개발할 떄 보인다.

 



2. 시간의 복잡도란?
 
알고리즘을 구성하는 명령어들이 몇번이나 실행됬는지 센 결과(frequency count)
                      +
각 명령어의 실행시간(execution time) 을 곱한 합계를 의미함!!!
 
그러나 각 명령어의 실행시간은 특정 하드웨어 혹은 프로그래밍 언어에 따라서 그 값이 달라질 수 있기 때문에 알고리즘의 일반적인 시간 복잡도는 명령어의 실제 실행시간을 제외한 명령어의 실행 횟수만을 고려하게 된다.


시간의 복잡도는 크게 세가지로 나눌 수 있다.
최상의 경우, 최악의 경우, 평균 => 이래서 표기법도 3개가 존재하는것이다.

시간과 공간은 반비례 하는 경향이 있다.
요즘은 공간보다는 시간이 우선이다!



3.시간 복잡도 표현법
 
Big O Noration(빅-오 표기법) --- O(N)
가장 많이 쓰이는 표기법으로 알고리즘 실행시간의 상한을 나타낸 표기법(최악의 경우)

Ω(오메가)표기법 --  Ω(N)
오메가 표기법은 알고리즘 실행시간의 하한을 나타낸 표기법 (최상의 경우)

Θ(세타)표기법 --- Θ(N)
세타 표기법은 알고리즘 실행시간의 평균시간을 나타낸 표기법(평균의 경우)



4.시간의 복잡도 계산법
 

명령이 끝날때마다 실행 횟수를 적어봅니다.

ex)

void  Func(int *a, n)

{

     int i=0, j=0;                                       1

     for (i = 0 ; i < n-1 ; i++)                      n      (i =0일때부터 i=n-1일때까지 계속 실행되죠)

         for(j=i+1; j<n ; j++)                        (n-1) * n (가장 많이 수행되는 경우를 생각합니다.)

            if (a[i] == a[j]) a[j] = 0 ;            (n-1) * (n-1)

}
 

명령어 실행횟수를 모두 더하면 2n²-2n+2  ->상수는 생략하고 최고차항만 생각한다. => O(n²)로 표기합니다.

 

ex)

int Func2(int a[], int size, int key)  {

   int i = 0;                                          1

   for (i = 0; i < size; i++)                      size + 1

       if(a[i] == key)                              size

       return i;                                      1

   return -1;                                        1

}

시간복잡도 O(size)
총 실행횟수 : 2size +4  => O(N) 

 

출처 : http://skmagic.tistory.com/entry/%EC%8B%9C%EA%B0%84%EC%9D%98-%EB%B3%B5%EC%9E%A1%EB%8F%84-%EC%B4%9D%EC%A0%95%EB%A6%AC%EC%95%8C%EA%B3%A0%EB%A6%AC%EC%A6%98

?

공부 게시판

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

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

    Date2003.08.18 By처누 Views928234
    read more
  2. 전수데이터를 생성하는 빠른 콤비나토리얼 프로그램 (Fast Combinatorial Programs Generating Total Data)

    Date2015.07.15 Category논문 ByJaeSoo Views642
    Read More
  3. 스코퍼스(Scopus) 지수

    Date2014.10.21 Category논문 ByJaeSoo Views857
    Read More
  4. [논문] Ubiquitous-City Integrated Authentication System (UCIAS) - Jae-Soo Jang, Hyung-Min Lim, Journal of Intelligent Manufacturing(JIM), February 2014, 장재수

    Date2014.02.21 Category논문 ByJaeSoo Views2029
    Read More
  5. [논문] 다중링크를 이용한 다양한 크기의 데이터 전송 (Data transmission of various size that use multiplex link) - 장재수,학위논문(석사), 숭실대학교 대학원 : 컴퓨터학과(일원) 컴퓨터통신 2003. 12

    Date2014.01.25 Category논문 ByJaeSoo Views2850
    Read More
  6. [논문] 조합과 순열 생성 알고리즘의 개선(Enhancement of Combination and Permutation Generation Algorithms) - 장재수,학위논문(박사), 숭실대학교 대학원 : 컴퓨터학과(일원) 컴퓨터통신 2013. 8

    Date2014.01.25 Category논문 ByJaeSoo Views2591
    Read More
  7. 제 논문에 실린 감사의 글입니다

    Date2013.06.12 Category논문 ByJaeSoo Views7191
    Read More
  8. 박사학위논문을 끝내고 감사하는 마음의 글

    Date2013.06.12 Category논문 ByJaeSoo Views5913
    Read More
  9. 로그(Log)에 대하여..

    Date2013.06.10 Category논문 ByJaeSoo Views3639
    Read More
  10. Excel 엑셀, 상용 로그, 자연 로그(LOG) 구하기 계산 함수; Common, Natural Logarithm

    Date2013.06.10 Category논문 ByJaeSoo Views6921
    Read More
  11. 논문 투고 과정

    Date2013.06.07 Category논문 ByJaeSoo Views4814
    Read More
  12. 수리과학 영어논문 작성법

    Date2013.06.07 Category논문 ByJaeSoo Views5217
    Read More
  13. 논문 작성과 형식 - 1.10 퇴고와 기타사항

    Date2013.05.19 Category논문 ByJaeSoo Views4827
    Read More
  14. 논문 작성과 형식 - 1.8 표와 그림

    Date2013.05.19 Category논문 ByJaeSoo Views5730
    Read More
  15. 논문 작성과 형식 - 1.9 주와 참고문헌의 처리

    Date2013.05.19 Category논문 ByJaeSoo Views4390
    Read More
  16. 논문 작성과 형식 - 1.7 인용과 인증

    Date2013.05.19 Category논문 ByJaeSoo Views4657
    Read More
  17. 논문 작성과 형식 - 1.6 논문 작성시 문장의 형식

    Date2013.05.19 Category논문 ByJaeSoo Views6227
    Read More
  18. 논문 작성과 형식 - 1.5 논문의 내용 전개

    Date2013.05.19 Category논문 ByJaeSoo Views4905
    Read More
  19. 논문 작성과 형식 - 1.4 논문의 내용구성

    Date2013.05.19 Category논문 ByJaeSoo Views5152
    Read More
  20. 논문 작성과 형식 - 1.3 논문의 작성의 개요

    Date2013.05.19 Category논문 ByJaeSoo Views5185
    Read More
  21. 논문 작성과 형식 - 1.2 학술논문의 형식

    Date2013.05.19 Category논문 ByJaeSoo Views6538
    Read More
Board Pagination Prev 1 2 3 4 Next
/ 4


즐겨찾기 (가족)

JAESOO's HOMEPAGE


YOUNGAE's HOMEPAGE


장여은 홈페이지


장여희 홈페이지


장여원 홈페이지


즐겨찾기 (업무)

알리카페 홀릭

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

말레이시아 KL Sentral 한국인 GuestHouse


즐겨찾기 (취미)

어드민아이디

유에코 사랑회

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

JServer.kr

제이서버 메타블로그

재수 티스토리


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

재수 강의 홈페이지


한소리


VTMODE.COM


숭실대 인공지능학과


숭실대 통신연구실


베너