버블정렬,소스사용에 대해서 여쭈어볼러고합니다
가온
질문 제목 : 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번주문을 배달하는 형식으로 만들고 싶은데
너무어렵습니다.. 도와주세요 ㅠㅠ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2685477 | 소수점이하 출력하는거요 | 널위해 | 2025-02-18 |
2685449 | printf배우고있는데요 궁금한게있어요 (8) | 꽃큰 | 2025-02-18 |
2685393 | c언어 질문이요.... | 붕붕 | 2025-02-18 |
2685365 | 윈도우7에서 visual studio c++6.0 (1) | 빛길 | 2025-02-17 |
2685317 | segmentation fault가 나요 | 가람 | 2025-02-17 |
2685292 | 다중스택질문 | 올해1살 | 2025-02-17 |
2685231 | C언어와 닷넷에 대해서 질문!! (2) | 설아 | 2025-02-16 |
2685206 | VisualBasic 과 DEV++ 의 장단점과 만든 파일 호환 가능하나요? | 에드워드 | 2025-02-16 |
2685154 | 배열 크기조절 | 해찬솔 | 2025-02-15 |
2685124 | 수정이거 제가 뭐가 잘못한거죠 ? | 아이돌 | 2025-02-15 |
2685096 | 포인터의 고수분들 모두 보세요!! 제발 ㅠ_ㅠ 헷갈려헷갈려..갈려헷.. (7) | 치킨마루 | 2025-02-15 |
2685045 | 전처리기 질문 | 치에미 | 2025-02-14 |
2685016 | 오류 좀 확인해 주시면 감사하겠습니다 | 초코맛사탕 | 2025-02-14 |
2684917 | 알고리즘을 이용한 행렬의 전치// 문제다운 문제네요. | 뿡뿡 | 2025-02-13 |
2684868 | 양방향 연결리스트에서 실행도중 죽는 이유좀 찾아주세요. (2) | 예다움 | 2025-02-13 |
2684844 | 시계프로그램인데 도저히 모르겠어요ㅠ (1) | 비내리던날 | 2025-02-12 |
2684812 | 레포트좀도와주세요ㅠㅠ (2) | 갈매빛 | 2025-02-12 |
2684780 | 채팅창 흉내내보려고하는데요 ㅜ.ㅜ (1) | 바름 | 2025-02-12 |
2684729 | 내일 시험인데 메모리 그리는것좀 도와주세요 ㅠ (1) | 상처주지마 | 2025-02-11 |
2684701 | 버퍼 관련 질문 3가지 (이전거랑 달라요) | 한국녀 | 2025-02-11 |