250929 Revision

2025. 9. 29. 11:29·📖TIL

알고리즘 성능을 수학적으로 나타내는 방법

정확한 실행 시간을 측정하는 것이 아니다
입력 크기를 N 이라고 가정, 성장의 속도

배열 요소가 10개일 때 1초, 100개 일때 10초 , 1000개 일때 100초가 걸린다
선형적으로 증가한다, O(N)


배열 요소가 10개일 때 1초, 100개일 때 100호, 1000개일 때 10000초
제곱으로 증가하고 있다 O(N^2)


BigO 는 성능의 '최고차항'만 남겨서 단순화 한 것
n-1 이라던지 /2 같은 상수 같은건 다 무시


for 를 3번 굴리는 알고리즘은 n^3 

 

 

O(n): 사람을 한 줄로 세워 차례대로 검사.

O(log n): 절반씩 줄여가며 검사.

O(2^n): 가능한 모든 경우를 일일이 다 시도.

 

 

지수 = "곱하기를 몇 번 반복했는가"

로그 = "곱하기 몇 번 해야 도달하는가"

빅오에서 지수는 주로 **조합 폭발(모든 경우 탐색)**에서 나타난다

 

 

쪼개기와 합치기의 반복

분할 ( Divide ) : 배열을 반으로 자르고

정복 ( Conquer ) : 쪼갠 배열을 재귀적으로 정렬

결합 ( Combine ) : 두 개의 정렬된 배열을 합병

 

시간 복잡도 , BigO 값

 

분할단계에서 로그값 Log² ( 이진수 로그 N )

Log N

 

합병단계, 각 단계마다 모든 N개 원소 다 보긴 해야한다

O(N)

 

N Log N

항상 안정적으로 이 속도를 가진다

최선의 케이스란 이미 정렬이 되어 있을때  N Log N

최악의 케이스 N Log N

평균 N Log N

 

 

DFS , BFS + 다익스트라 + A* 로 길 찾기
A*
목표지점까지 제일 빨리 가기 위해
현재까지의 비용 + 다음으로 갈 수 있는 경로 중 가장 빠른 경로를 판단하는걸 반복

F : Full Cost , G + H , 최종 걸릴 법한 값
G : 시작점 에서부터 현재까지 실제 이동 거리
H : 남은 거리 예측 ( Heuristic )

'📖TIL' 카테고리의 다른 글

250930 메모리 revision  (0) 2025.09.30
250929  (0) 2025.09.29
250926  (0) 2025.09.26
250926 알고리즘  (0) 2025.09.26
250926 Revision  (0) 2025.09.26
'📖TIL' 카테고리의 다른 글
  • 250930 메모리 revision
  • 250929
  • 250926
  • 250926 알고리즘
DevHoChan
DevHoChan
맨땅에서 시작하는 코딩 도전
  • DevHoChan
    Debugging Life
    DevHoChan
  • 전체
    오늘
    어제
    • 분류 전체보기 (374)
      • 🕹️Game Life (1)
      • 🖥️Computer Science (5)
      • 📖TIL (141)
        • 🔥Projects (16)
        • 💡DevTips (5)
        • 🤔발생한 문제와 해결 (5)
        • 🔮Unity Graphics (5)
        • 🎤Interview (3)
        • ✅CodingTest (9)
      • 🚀Game Release (4)
      • 🧊Unity Basic (58)
        • 📌용어 사전 (1)
        • 에디터&인터페이스 (3)
        • 디버그 (1)
        • 라이프사이클 (4)
        • 게임오브젝트 (4)
        • 프리팹 (1)
        • 오브젝트풀링 (4)
        • 애트리뷰트 (2)
        • 트랜스폼 (4)
        • 물리&충돌 (1)
        • 프레임&델타타임 (4)
        • 코루틴&이벤트 (7)
        • 수학&보정함수 (3)
        • 디자인패턴 (9)
        • UGUI (3)
        • 벡터 ( Vector ) (3)
        • 씬 ( Scene ) (2)
        • 데이터 관리 (2)
      • ⭐C Sharp (99)
        • 📌용어 사전 (1)
        • 📌문법 사전 (6)
        • 메모리 관리 (3)
        • 00. 문법 (17)
        • 01. 변수 (3)
        • 02. 자료형 (2)
        • 03. 연산자 (6)
        • 04. 조건문 (2)
        • 05. 반복문 (2)
        • 06. 배열 (3)
        • 07. 메서드(함수) (7)
        • 08. 열거형 (3)
        • 09. 구조체 (2)
        • 10. 참조 (2)
        • 11. 객체 지향 (11)
        • 12. 델리게이트 (3)
        • 13. 디자인 패턴 (7)
        • 14. LINQ (1)
        • 📂▼자료구조 (2)
        • 15-1. 제네릭 (3)
        • 15-2. 배열 (4)
        • 15-3. 리스트 (2)
        • 15-4. 스택과 큐 (2)
        • 15-5. 딕셔너리 해시테이블 (2)
        • 15-6. 트리와 그래프 (3)
      • 📊Algorithm (16)
        • BigO (2)
        • 정렬 (4)
        • 셔플 (2)
        • 탐색 (6)
        • 최적화 (1)
      • 📝Game Design (16)
      • 🤖​AI Tools (12)
        • AI 리뷰 분석 (6)
        • Player2 (0)
        • 3D 모델링 (1)
        • 2D 스프라이트 (0)
        • 이미지 (2)
        • 사운드 (1)
        • 동영상 (1)
        • 문서 (1)
      • 🌍Network (6)
      • 🌱Github (11)
        • 기본 개념 (7)
        • 명령어 (1)
        • 도구 활용 (1)
      • ⚙️Visual Studio (5)
        • 🔧설치 및 환경설정 (2)
        • ⌨️HotKey (1)
        • 🚨디버깅 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    csharp
    gamedesign
    부트캠프
    algorithm
    til
    자료구조
    문법
    디자인패턴
    OOP
    유니티
    게임디자인
    게임기획
    unity
    CodingTest
    GitHub
    자료형
    메모리관리
    기획
    객체지향
    c#
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
DevHoChan
250929 Revision
상단으로

티스토리툴바