일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 충남 천안
- 졸업 작품 소재
- 안드로이드 앱 개발
- 프로젝트
- 네트워크 프로그래밍
- 강의
- 산책하기 좋은 곳
- 동영상
- 캡슐화
- c언어
- 독립기념관
- 추천
- 표준 입출력
- 알고리즘
- 언제나휴일
- 실습
- 유튜브 동영상 강의
- 표준 라이브러리 함수
- c#
- 원격 제어 프로그램
- 무료 동영상 강의
- 소스 코드
- 실습으로 다지는 c#
- 파이썬
- 동영상 강의
- 소켓 통신
- 언제나 휴일
- 클래스 다이어그램
- C++
- Windows Forms
Archives
- Today
- Total
프로그래밍 언어 및 기술 [언제나휴일]
[C언어 소스] 연결리스트를 이용하여 구현한 큐 본문
안녕하세요. 언제나 휴일이예요.
이번에는 연결리스트를 이용하여 구현한 큐의 소스 코드예요.
큐는 자료를 한쪽으로 보관하고 다른쪽에서 꺼내는 FIFO(First In First Out) 방식의 자료구조입니다. 큐에 자료를 보관하는 연산을 PUT 혹은 ENQUEUE라 말하고 꺼내는 연산을 GET 혹은 DEQUEUE라고 말합니다. 그리고 보관할 위치 정보를 rear, 꺼낼 위치 정보를 front라고 말해요.
연결리스트를 이용하여 구현한 큐에서는 보관할 때 rear 뒤에 보관하고 꺼낼 때 front에 있는 것을 꺼냅니다. 그리고 보관할 때 허용하는 메모리 범위 내에서 보관할 수 있어 꽉 찼는지 확인할 필요가 없습니다.
알고리즘
PUT 연산
now = MakeNode(data) (노드 생성)IF Queue Is Empty (비어있을 때)
front = now (front를 now로 설정)
Else (비어있지 않을 때)rear의 next= now (rear의 netx를 now로 설정)
rear=now (rear를 now로 설정)GET 연산
IF Queue is empty Then (비었으면)
Underflow (버퍼 언더플로우)
Else
now = frontdata = front의 data (data를 front의 data로 설정)
fornt =now의 next (front를 now의 next로 설정)
DisposeNode(now) (now 노드 소멸)
data 반환
소스 코드
//큐 - 연결리스트 이용
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct Node //노드 정의
{
int data;
struct Node *next;
}Node;
typedef struct Queue //Queue 구조체 정의
{
Node *front; //맨 앞(꺼낼 위치)
Node *rear; //맨 뒤(보관할 위치)
int count;//보관 개수
}Queue;
void InitQueue(Queue *queue);//큐 초기화
int IsEmpty(Queue *queue); //큐가 비었는지 확인
void Enqueue(Queue *queue, int data); //큐에 보관
int Dequeue(Queue *queue); //큐에서 꺼냄
int main(void)
{
int i;
Queue queue;
InitQueue(&queue);//큐 초기화
for (i = 1; i <= 5; i++)//1~5까지 큐에 보관
{
Enqueue(&queue, i);
}
while (!IsEmpty(&queue))//큐가 비어있지 않다면 반복
{
printf("%d ", Dequeue(&queue));//큐에서 꺼내온 값 출력
}
printf("\n");
return 0;
}
void InitQueue(Queue *queue)
{
queue->front = queue->rear = NULL; //front와 rear를 NULL로 설정
queue->count = 0;//보관 개수를 0으로 설정
}
int IsEmpty(Queue *queue)
{
return queue->count == 0; //보관 개수가 0이면 빈 상태
}
void Enqueue(Queue *queue, int data)
{
Node *now = (Node *)malloc(sizeof(Node)); //노드 생성
now->data = data;//데이터 설정
now->next = NULL;
if (IsEmpty(queue))//큐가 비어있을 때
{
queue->front = now;//맨 앞을 now로 설정
}
else//비어있지 않을 때
{
queue->rear->next = now;//맨 뒤의 다음을 now로 설정
}
queue->rear = now;//맨 뒤를 now로 설정
queue->count++;//보관 개수를 1 증가
}
int Dequeue(Queue *queue)
{
int re = 0;
Node *now;
if (IsEmpty(queue))//큐가 비었을 때
{
return re;
}
now = queue->front;//맨 앞의 노드를 now에 기억
re = now->data;//반환할 값은 now의 data로 설정
queue->front = now->next;//맨 앞은 now의 다음 노드로 설정
free(now);//now 소멸
queue->count--;//보관 개수를 1 감소
return re;
}
언제나휴일 여행 및 산책
'C & C++ > C++ 예제 및 소스' 카테고리의 다른 글
[C언어 소스] 부분 문자열 비교하는 함수 만들기 (0) | 2025.01.09 |
---|---|
[C언어 소스] 문자열 길이를 계산하는 함수 만들기 (0) | 2025.01.08 |
Queue를 이용한 스케쥴러 시뮬레이션 [C++] (1) | 2025.01.08 |
파서 트리를 이용한 계산기 [C++] (0) | 2025.01.08 |
함수 개체, 회원 및 회원 컬렉션 구현[C++] (0) | 2025.01.08 |
개체 출력자 실습 – 회원 클래스 및 쉬프트 연산자 중복 정의 [C++] (0) | 2025.01.08 |
다형성 실습 – 오케스트라, 음악가, 피아니스트, 드러머 [C++] (0) | 2025.01.08 |
상품과 할인 상품 – 상속 실습 [C++] (0) | 2025.01.08 |