버블정렬,소스사용에 대해서 여쭈어볼러고합니다
가온
질문 제목 : C언어 코딩 부탁드려요질문 요약 :#include stdio.h
#include string.h
#include time.h
#include stdlib.htypedef enum menue{ //메뉴 정의
fried = 51, sourced = 52, spicysourced = 53, chilly = 54, galicfried=55, soysourced=56, fried_sourced=61,fried_soysourced=62,sourced_soysourced=63,
cokeservice=71,cokemini=72,cokelarge=73,saladservice=74,salad=75,cornsalad=76, mustardsource=77} MENU;typedef enum address{ //대주소 정의
Q = 1, W = 2, E = 3, R = 4, T = 5} ADDRESS;typedef struct order{ //주문 구조체
int ordernum;
int add;
int menu[10];
char subadd[30];
int price;
char rider[30];
} ORDER;int main(void) //메인함수
{
int sum = 0;
int totalorder = 0; //총 주문된 번호
i int i = 0; //for문 쓰기위해 정의
int ran = 0; //랜덤 수 입력용
int job; //실행할 작업
ORDER *ord[100]={NULL}; //포인터구조체 100개 정의
ORDER od[100]={NULL}; //구조체 100개 정의 for( i=0 ; i100 ; i++)
{
ord[i] = &od[i];
}
while(1)
{
printf(배달관리 프로그램을 시작합니다.\n); printf(총 주문 수 : %d\n, totalorder);joborder:
printf(실행할 작업을 입력하세요. \n 1 = 주문등록\n 2 = 주문확인\n 3 = 계산\n 4 = 총 수입\n 0 = 종료\n입력 : ); scanf(%d, &job); printf(=============================================================================\n);
switch(job)
{
case 1:
{
totalorder += 1; //주문된 번호에 1 추가
ord[totalorder]; //ord구조체[주문번호] 정의
ord[totalorder]-ordernum = totalorder; //[구조체 내부의 주문번호를 총 주문번호로]
addinput: printf(주문번호 : %d\n, ord[totalorder]-ordernum);
printf(Q = 1, W = 2, E = 3, R = 4, T = 5\n);
printf(대단위 주소를 입력하세요 : );
scanf(%d, &ord[totalorder]-add); if(ord[totalorder]-add 1 || ord[totalorder]-add 5)
{
printf(잘못된 입력입니다. 다시 입력하세요.\n);
goto addinput;
}
printf(\n); printf(세부 주소를 입력하세요 : );
fflush(stdin);
gets(ord[totalorder]-subadd);
fflush(stdin);
printf(\n); printf(메뉴를 등록하세요. 최대 10개 등록 가능합니다. 0을 입력하면 입력을 마칩니다\n);
printf(일반: 후라이드 51, 양념 52, 스파이스 53,칠리 54, 갈릭 55, 간장 56\n); // PrintAllMenu 등의 함수로 메뉴 출력하게 만들 것
printf(반반: 후양 61, 반반후간 62, 반반양간 63\n);
printf(콜라 : 서비스 71, 소 72, 대 73\n);
printf(샐러드 : 서비스 74, 샐러드 75, 콘 76, 머스타드소스 77\n);
printf(메뉴 : );
//0 입력하면 메뉴 입력 중지. for(i = 0 ; i 10 ; i++)
{
scanf(%d, &ord[totalorder]-menu[i]); if(ord[totalorder]-menu[i] == 0)
break;
}
printf(=============================================================================\n);
printf(주문 정보입니다\n); printf(주문번호 : %d // 주소 : , ord[totalorder]-ordernum); //주문 번호 출력
ord[totalorder]-add; switch ( ord[totalorder]-add ) //대주소 출력.. 이 문은 PrintAdd 등으로 함수로 만들 것
{
case 1:
printf(A );
break;
case 2:
printf(B );
break;
case 3:
printf(C );
break;
case 4:
printf(D );
break;
case 5:
printf(E );
break;
}
puts(ord[totalorder]-subadd); //세부주소 출력 ord[totalorder]-price = 0; //가격 기본설정 0원 for(i = 0 ; i 10; i++) //메뉴 출력. 0이 입력된 경우에 빠져나감.. 이 문도 PrintMenu 등으로 함수로 만들 것
switch ( ord[totalorder]-menu[i] )
{
case 51:
printf(후라이드 치킨, );
ord[totalorder]-price += 17000;
break;
case 52:
printf(양념 치킨, );
ord[totalorder]-price += 17000;
break;
case 53:
printf(스파이스 치킨, );
ord[totalorder]-price += 17000;
break;
case 54:
printf(칠리 치킨, );
ord[totalorder]-price += 17000;
break;
case 55:
printf(갈릭 후라이드, );
ord[totalorder]-price += 18000;
break;
case 56:
printf(간장 치킨 );
ord[totalorder]-price += 17000;
break;
case 61:
printf((반반)후라이드 양념, );
ord[totalorder]-price += 19000;
break;
case 62:
printf((반반)후라이드 간장, );
ord[totalorder]-price += 19000;
break;
case 63:
printf((반반)양념 간장, );
ord[totalod[totalorder]-price += 19000;
break;
case 71:
printf(콜라 서비스, );
break;
case 72:
printf(콜라 소, );
ord[totalorder]-price += 1000;
break;
case 73:
printf(콜라 대, );
ord[totalorder]-price += 1500;
break;
case 74:
printf(샐러드 서비스, );
break;
case 75:
printf(샐러드 );
ord[totalorder]-price += 2000;
break;
case 76:
printf(콘샐러드, );
ord[totalorder]-price += 3000;
break;
case 77:
printf(머스타드 소스, );
ord[totalorder]-price += 500; case 0:
printf(\n);
goto orderend;
}
orderend:
printf(총 금액 : %d\n,ord[totalorder]-price); //switch문 안에 가격 추가
srand(time(NULL)); //중복방지
rider: ran = rand()%5+1; //랜덤 1~5까지 정의
switch(ran)
{
case 1:
strcpy(ord[totalorder]-rider,Q);
break;
case 2:
strcpy(ord[totalorder]-rider,W);
break;
case 3:
strcpy(ord[totalorder]-rider,E);
break;
case 4:
strcpy(ord[totalorder]-rider,R);
break;
case 5:
strcpy(ord[totalorder]-rider,T);
break;
}
for ( i=0 ; itotalorder ; i++)
if(strcmp(ord[i]-rider,ord[totalorder]-rider) == 0)
{
goto rider;
}
//
printf(배달자 : );
puts(ord[totalorder]-rider);
printf(주문완료되었습니다.\n);
printf(=============================================================================\n); goto joborder;
}
case 2:
{
int a=0;
printf(주문번호 :); //주문번호를 입력하여 해당 주문 내용을 출력하는 내용.
scanf(%d,&a); switch ( ord[a]-add ) //대주소 출력
{
case 1:
printf(A );
break;
case 2:
printf(B );
break;
case 3:
printf(C );
break;
case 4:
printf(D );
break;
case 5:
printf(E );
break;
}
puts(ord[a]-subadd); printf(주문 매뉴: ); for(i = 0 ; i 10; i++)
switch ( ord[a]-menu[i] )
{
case 51:
printf(후라이드 치킨, );
break;
case 52:
printf(양념 치킨, );
break;
case 53:
printf(스파이스 치킨, );
break;
case 54:
printf(칠리 치킨, );
break;
case 55:
printf(갈릭 후라이드, );
break;
case 56:
printf(간장 치킨 );
break;
case 61:
printf((반반)후라이드 양념, );
break;
case 62:
printf((반반)후라이드 간장, );
break;
case 63:
printf((반반)양념 간장, );
break;
case 71:
printf(콜라 서비스, );
break;
case 72:
printf(콜라 소, );
break;
case 73:
printf(콜라 대, );
break;
case 74:
printf(샐러드 서비스, );
break;
case 75:
printf(샐러드 );
break;
case 76:
printf(콘샐러드, );
break;
case 77:
printf(머스타드 소스, );
case 0:
goto price;
}
price:
printf(\n);
printf(가격 : %d\n,ord[a]-price);
printf(배달자 : );
puts(ord[a]-rider);
printf(=============================================================================\n); goto joborder;
}
case 3:
{
int a=0;
printf(주문번호 :); //주문번호를 입력하여 해당 주문을 완료건으로 만드는 내용
scanf(%d,&a);
sum += ord[a]-price;
strcpy(ord[a]-rider,배달완료);
printf(주문번호 %d 번 계산완료\n,a);
printf(=============================================================================\n);
goto joborder;
}
case 4:
{
printf(총 수입 : %d\n,sum);
printf(=============================================================================\n);
goto joborder;
}
case 0:
{
break;
}
default:
{
printf(잘못된 입력입니다. 다시 입력하세요.\n);
goto joborder;
}
}
break;
}
return 0;
}질문 내용 :이 소스에서 배달원이 5명(A,B,C,D,E)가 다 배달을 나간상태에서 다시 주문을 받을 때 소스가 멈춰버리는데
예로들면 1~5번까지 배달을 다 나간 상태에서 아직 미복귀하였고, 6번 주문이 왔을 경우에 대기상태로 만들고
만약 배달원 한명이 복귀를 했을경우 그 6번주문을 배달하는 형식으로 만들고 싶은데
너무어렵습니다.. 도와주세요 ㅠㅠ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695270 | 질문이요..swap 관한겁니다..ㅠㅠ (3) | 콩알녀 | 2025-05-19 |
2695244 | 노땅초보궁금한게 하나 있는데요..반복문(while문)초보자질문 (6) | 큰꽃늘 | 2025-05-18 |
2695166 | do while 문 어떤것이잘못된건지 모르겠어요 (2) | 아이폰 | 2025-05-18 |
2695122 | 구조체에 대해 물어보고 싶은게 있습니다 ^^^.. (7) | 수련 | 2025-05-17 |
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |
2694958 | 로직이 변한다는 것에 대해서 궁금합니다. | 튼동 | 2025-05-16 |
2694929 | 열혈강의 25-2 두번째 문제 질문 | 지우개 | 2025-05-15 |
2694900 | dequeue 에서 리턴값 프린트 방법알려주세요 오늘 12시까지 대화방에 있습니다 도와주세요 | 미투리 | 2025-05-15 |
2694854 | 절대값을 구할때 (2) | 그녀는귀여웠다 | 2025-05-15 |
2694827 | 이제 어떻게 공부해야할지 모르겠네요 | 새얀 | 2025-05-14 |
2694778 | 순열 계산요. | 맛조이 | 2025-05-14 |
2694754 | ShowWindow 함수를 이용하려 하는데 질문있습니다. (2) | 파도 | 2025-05-14 |
2694731 | 리눅스 커널의 시작점 질문 | 미르 | 2025-05-13 |
2694702 | 이거 뭐가문제인가요 코드수정좀 (3) | 맑은 | 2025-05-13 |
2694675 | C언어 후위표기를 중위표기로 | 앨런 | 2025-05-13 |
2694646 | 안녕하세요 파일 합치기 함수! (1) | 연블루 | 2025-05-13 |
2694618 | 잘몰라서 설명부탁드립니다. scanf 관련 (3) | 파라 | 2025-05-12 |