Skip to content

mine-kim/programmers-java

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

43 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Programmers solutions in Java

문제 유형 위치
탐욕법 greedy
다이나믹 프로그래밍 dp
DFS dfs
BFS bfs
이분탐색 binarysearch
투포인터 twopointers
슬라이딩 윈도우 slidingwindow
정렬 sort
그래프 graph
자료구조(스택 & 큐) stackqueue
자료구조(해시) hash
완전탐색 bruteforce
백트래킹 backtracking
자료구조(힙) heap
수학적 문제 mathematics
문자열 처리 string
복합 유형 및 기타 courses

1. 일반적인 시간 복잡도 기준과 입력 크기

대부분의 컴퓨터에서는 1초에 약 10^8번(1억)의 연산을 처리할 수 있다고 가정

입력 크기 n 적절한 시간 복잡도 설명
n ≤ 10 O(n!), O(2^n) 매우 작은 입력이므로 완전 탐색(Brute Force)이나 재귀적 백트래킹도 허용
n ≤ 20 O(2^n), O(n!) 완전 탐색, 재귀적 백트래킹 가능하며, 모든 경우의 수를 시도해도 가능한 크기
n ≤ 100 O(n^3) 3중 반복문을 허용하며, 그래프 문제에서 플로이드 워셜과 같은 알고리즘 가능
n ≤ 1,000 O(n^2) 2중 반복문을 사용한 브루트 포스동적 계획법(DP)이 적합
n ≤ 100,000 O(n log n) 합병 정렬, 힙 정렬, 퀵 정렬(평균), 이진 탐색과 같은 정렬 알고리즘이 적합하며, 대부분의 효율적인 탐색 알고리즘도 가능
n ≤ 1,000,000 O(n) 단일 반복문, 선형 탐색, 해시 테이블 등을 사용하는 알고리즘이 적합
n > 10^7 O(log n) 또는 O(1) 매우 큰 입력 크기이므로 로그 시간 또는 상수 시간의 알고리즘이 필요

2. 제한 조건을 통해 시간 복잡도 판단하는 방법

  • 제한 조건 분석: 문제에 주어진 제한 조건을 통해 n의 크기를 확인합니다. 예를 들어, 1 ≤ n ≤ 1,000이라면 **O(n^2)**의 시간 복잡도가 적절할 수 있습니다.
  • 연산 가능 횟수 추정: 일반적으로 1억 번 연산을 1초로 가정하여 입력 크기 n에 따른 시간 초과 여부를 판단합니다.
  • 적합한 알고리즘 선택: 문제의 입력 크기에 따라 적절한 알고리즘을 선택합니다. 이때 알고리즘의 시간 복잡도를 알고 있으면 도움이 됩니다.

3. 시간 복잡도에 따른 알고리즘 선택 예시

시간 복잡도 적절한 알고리즘 유형 예시 문제
O(1) 해시 테이블, 배열 인덱싱 상수 시간에 접근 가능한 데이터 조회, 스택에서의 push/pop 연산
O(n) 슬라이딩 윈도우, 투 포인터, 해시맵, 큐, BFS 배열의 연속된 구간에서 최댓값을 찾거나 중복 체크 문제, BFS 탐색
O(n log n) 합병 정렬, 퀵 정렬, 이진 탐색, 균형 이진 트리, 그리디, 분할 정복, 위상 정렬 대규모 데이터를 정렬하거나, 이진 탐색을 사용해 값을 찾는 문제
O(n^2) 브루트 포스, 다이나믹 프로그래밍, 플로이드-워셜, 스택, DFS 그래프의 모든 정점 간 탐색, 2중 루프를 사용하는 최적화 문제
O(2^n) 백트래킹, 분할 정복, 동적 계획법 (메모이제이션), 완전 탐색 입력 크기가 작고, 모든 경우를 탐색하는 문제
O(n!) 백트래킹, 완전 탐색 입력 크기가 작고, 모든 경우를 탐색하는 문제

About

Programmers solutions in Java

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages