본문 바로가기
  • 개발 삽질 블로그

프로그래밍/자료구조2

큐(Queue) Queue 선입선출(First In First Out; FIFO)의 자료구조로 대기열이라고도 한다 가장 먼저 들어온 데이터가 가장 먼저 나가는 구조 삽입은 맨 뒤에서만 이루어지고, 삭제는 맨 앞에서만 이루어지는 구조, 중간에 끼워넣기 X Queue 용어 enqueue(data) : 큐의 맨뒤에 데이터 삽입 dequeue: 큐의 맨앞 데이터 삭제 및 반환 front : 큐의 맨앞 데이터 rear(back): 큐 맨뒤 데이터 size: 큐 크기 가득찬 큐에 데이터를 삽입하려고 시도하면 overflow, 빈 큐에서 데이터를 삭제하려고 시도하면 underflow 발생 Queue 구현 Java에서 큐는 array나 LinkedList로 구현할 수 있음, 각자 장단점이 다름 1) Array로 구현 배열로 구현 시 .. 2023. 12. 22.
스택(Stack) *코테 준비용으로 자료구조 정리 시작, 자바 위주로 정리 스택(Stack): 스택은 쌓아놓은 더미라는 의미로 스택은 데이터를 쌓는 LIFO(Last In First Out)의 특성을 갖는 선형 자료구조 -top 부분으로만 데이터 입출력이 되기 때문에 가장 먼저 들어온 데이터가 가장 마지막으로 나가고, 가장 마지막에 들어온 데이터가 가장 먼저 나가는 구조 -웹 브라우저의 방문 기록이나 재귀 함수 호출 등에서 사용 Top : 스택의 가장 위에 있는 데이터 Bottom: 스택의 가장 아래 있는 데이터 스택이 꽉 차면(capacity == size) 포화상태라고 하며, Full Stack이라고 한다. 스택 연산 pop() : 스택에서 top에 있는 항목을 제거 push(element) : element 하나를 .. 2023. 12. 15.