도와주세요ㅠ...!! 원형큐를 이용한 메뉴주문 프로그램
얀별
질문 제목 :
원형큐를 이용 랜덤하게 메뉴가 큐에 삽입됩니다
메뉴의 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);
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2694503 | 프로그램 연산 후 바로 종료되는 현상 (6) | Judicious | 2025-05-11 |
2694450 | while문질문입니다. (1) | 허리품 | 2025-05-11 |
2694420 | C언어 질문할게요(유니코드,자료형,버퍼,캐스트연산자) | 은새 | 2025-05-11 |
2694370 | 내일까진데 함수호출 제발 도와주세요!!!!!!!!!11 | 들찬 | 2025-05-10 |
2694339 | putchar()의 괄호 안에 int c=10;로 전에 선언된 c를 넣으면 안되는 이유에서 제가 생각한 것이 그 이유가 되는지 확인하고 싶습니다. (3) | 미르 | 2025-05-10 |
2694316 | 이 코드 어디가 잘못되었는지 고수분들 ㅠㅠ (2) | 나빛 | 2025-05-10 |
2694285 | 언어 공부하는 과정 좀 추천해주세요! (1) | 아빠몬 | 2025-05-09 |
2694258 | 카운터.. 질문입니다. (4) | 하늘빛눈망울 | 2025-05-09 |
2694229 | 단순한 질문이요 (8) | 여름 | 2025-05-09 |
2694202 | 용돈을 가지고 할 수 있는 일을 여러가지로 출력하는 방법 좀 알려주세요! (2) | 미나 | 2025-05-09 |
2694145 | 화면깜빡임을 없애고 싶은데요... (1) | 어서와 | 2025-05-08 |
2694069 | unsigned 질문입니다. | 힘차 | 2025-05-07 |
2694012 | 전공 비전공자 개발자 (10) | 말글 | 2025-05-07 |
2693984 | 오버로딩이 무엇인가요? (2) | 헛매질 | 2025-05-07 |
2693956 | PlaySound재생이 안됩니다!(C에 음악넣기) | 지존 | 2025-05-06 |
2693928 | &와 *의 사용에 관한 명확한 이해 | 제나 | 2025-05-06 |
2693903 | 반복문 설명좀요 ㅠㅠ (2) | 란새 | 2025-05-06 |
2693869 | stdio.h 는 왜 쓰는건가요? (1) | 큰꽃들 | 2025-05-06 |
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |