순환 대기 열 - 순차 저장 구조 - 데이터 구조
1879 단어 데이터 구조
간단 한 기본 조작, 입 대, 출 대, 맞 춤 형 요 소 를 취하 여 빈 대기 열, 대기 열 길 이 를 판단 합 니 다.
예 코드:
#include
#include
#include
#define ERROR 0
#define OK 1
#define OVERFLOW -1
#define MAXSIZE 10
typedef int Elemtype;
typedef int Status;
typedef struct SqQue
{
Elemtype *base;
int front;
int rear;
}SqQue;
Status InitQue(SqQue &q) //initialize the queue
{
q.base=(Elemtype*)malloc(MAXSIZE*sizeof(Elemtype));
if(!q.base) exit(OVERFLOW);
q.front=q.rear=0;
return OK;
}
bool EmptyQue(SqQue q) //if empty
{
if(q.front==q.rear) return true;
else return false;
}
Status EnQue(SqQue &q,Elemtype e)
{
if((q.rear+1)%MAXSIZE==q.front) return ERROR; //queue full
q.base[q.rear]=e;
q.rear=(q.rear+1)%MAXSIZE;
return OK;
}
Status DisplayQue(SqQue q)
{
int i;
if(EmptyQue(q)) printf("The queue is empty!
");
else
{
i=q.front;
while(i!=q.rear)
{
printf("%d ",q.base[i]);
i=(i+1)%MAXSIZE;
}
printf("
");
return OK;
}
}
int QueLength(SqQue q)
{
return (q.rear-q.front+MAXSIZE)%MAXSIZE;
}
Status DeQue(SqQue &q)
{
Elemtype e;
if(EmptyQue(q)) return ERROR;
e=q.base[q.front];
q.front=(q.front+1)%MAXSIZE;
return OK;
}
Status GetQueHead(SqQue q,Elemtype &e)
{
if(EmptyQue(q)) return ERROR; //queue empty
e=q.base[q.front];
return OK;
}
int main()
{
SqQue que;
int n,i,len;
Elemtype e;
InitQue(que);
if(EmptyQue(que)) printf("The initial queue is empty.
");
printf("Input the number of queue n(don't greater than MAXSIZE):");
scanf("%d",&n);
for(i=0;i
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
정수 반전Udemy 에서 공부 한 것을 중얼거린다 Chapter3【Integer Reversal】 (예) 문자열로 숫자를 반전 (toString, split, reverse, join) 인수의 수치 (n)가 0보다 위 또는 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.