원형큐(순환큐) 관련 프로그램 질문!!!
조히
원형큐를 이용 랜덤하게 메뉴가 큐에 삽입됩니다
메뉴의 TERM에 따라 for문을 돌다 Dequeue(&que)로 데이터를뽑아 출력되도록하고싶은데 안되네여...
if(make==0 && !QIsEmpty(&que)) {
make = Dequeue(&que);
switch(make){
case 10: printf(\n파스타가 나왔습니다 \n\n); break;
case 15: printf(\n리조또가 나왔습니다 \n\n); break;
case 20: printf(\n피자가 나왔습니다 \n\n); break;
}
이부분 조건이 잘못된거같은데...지적과 조언 부탁드립니다
for문을 돌다 조건이 만족하면
Dequeue(&que) 함수를 이용 메뉴가 나왔다는 메세지가 출력되도록
질문 내용 :
#include stdio.h
#include stdlib.h
#include time.h //1970년 1월 1일 부터 지금까지의 초값을 반환한다
#define C_QUEUE_H
#define TRUE 1
#define FALSE 0
#define QUE_LEN 80 //테이블 갯수
typedef int Data;
typedef struct _cQueue
{
int front;
int rear;
Data queArr[QUE_LEN];
} CQueue;
typedef CQueue Queue;
void QueueInit(Queue *pq);
int QIsEmpty(Queue *pq);
void Enqueue(Queue *pq,Data data);
Data Dequeue(Queue *pq);
Data QPeek(Queue *pq);
void QueueInit(Queue *pq) //공백 큐일때 frotn=rear
{
pq -front =0;
pq -rear =0;
}
int QIsEmpty(Queue *pq)
{
if(pq -front == pq -rear) //공백 큐일때
return TRUE;
else
return FALSE;
}
int NextPosIdx(int pos) //큐 다음 위치에 해당하는 인덱스 값 변환
{
if(pos == QUE_LEN-1) //배열 마지막요소 인덱스 값이라면
return 0;
else
return pos+1;
}
void Enqueue(Queue *pq, Data data)
{
if(NextPosIdx(pq-rear) == pq-front) //큐가 꽉 찼을때
{
printf(테이블 꽉찼습니다!!\n);
exit(-1);
}
pq -rear = NextPosIdx(pq-rear); //rear을 한칸 이동
pq-queArr[pq-rear]=data; //rear이 가리키는 곳에 데이터 저장
}
Data Dequeue(Queue *pq)
{
if(QIsEmpty(pq))
{
printf(큐 메모리 에러\n);
exit(-1);
}
pq -front = NextPosIdx(pq-front); //front를 한칸 이동
return pq-queArr[pq-front]; //front가 가리키는 데이터 반환
}
Data QPeek(Queue *pq)
{
if(QIsEmpty(pq))
{
printf(큐 메모리 에러\n);
exit(-1);
}
return pq -queArr[NextPosIdx(pq-front)];
}
int main()
{
int CUS_TERM = 30; //손님 주문 간격
int Pasta = 0;
int Pasta_TERM =10;
int Risotto = 1;
int Risotto_TERM =15;
int Pizza = 2;
int Pizza_TERM =20;
int make=0; //제작 진행 상황
int Pasta_Ord = 0;
int Risotto_Ord = 0;
int Pizza_Ord =0;
int i;
Queue que; //큐생성
QueueInit(&que); //큐초기화
srand(time(NULL)); //난수 생성함수(실행 시간에 따라 랜덤하게 수가 나옴)
for(i=0;i3000;i++) //1회 회전은 1초의 시간을 의미
{
if(i % CUS_TERM ==0)
{
printf(\n%d초가 지났습니다\n,i);
switch(rand()%3)
{
case 0: //파스타 주문시
Enqueue(&que,Pasta_TERM);
Pasta_Ord+=1;
printf(파스타가 주문되었다.\n);
break;
case 1: //리조또 주문시
Enqueue(&que,Risotto_TERM);
Risotto_Ord+=1;
printf(리조또가 주문되었다.\n);
break;
case 2: //피자 주문시
Enqueue(&que,Pizza_TERM);
Pizza_Ord+=1;
printf(피자가 주문되었다.\n);
break;
}
}
if(make==0 && !QIsEmpty(&que)) {
make = Dequeue(&que);
switch(make){
case 10: printf(\n파스타가 나왔습니다 \n\n); break;
case 15: printf(\n리조또가 나왔습니다 \n\n); break;
case 20: printf(\n피자가 나왔습니다 \n\n); break;
}
// Dequeue(&que);
}
make --; //make값이 감소되어 0이되면 메뉴가 완성되었다는 뜻 }
printf(\####### 아직 만들고있는 메뉴들...########\n);
while(!QIsEmpty(&que))
{
switch(Dequeue(&que)){
case 10: printf(파스타가 조리중 \n\n); break;
case 15: printf(리조또가 조리중 \n\n); break;
case 20: printf(피자가 조리중 \n\n); break;
}
}
printf(테이블 수:%d \n, QUE_LEN);
printf(Pasta 주문량:%2d \n,Pasta_Ord);
printf(Risotto 주문량:%2d \n,Risotto_Ord);
printf(Pizza 주문량:%2d \n,Pizza_Ord);
}