버블정렬,소스사용에 대해서 여쭈어볼러고합니다
가온
질문 제목 : 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번주문을 배달하는 형식으로 만들고 싶은데
너무어렵습니다.. 도와주세요 ㅠㅠ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676182 | 숫자 순서대로 배열하는법 | 권뉴 | 2024-11-24 |
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |