마지막 질문...
유우
질문 제목 : 마지막 질문
코드 추가 방법
질문 내용 :
제가 밑의 코드로코딩중인데요
지금 프로그램에서는 메뉴를 주문할때 안주 1개, 술 1개씩만 주문이 되고
안주 1개가 주문되어 있는 상태에서 다른 안주 1개를 다시 선택하면
추가가 되는게 아니라 앞의 안주에 덮어씌워져 버리거든요
여기에수량의 개념을 추가 한다던지 앞의 안주와 겹쳐지지 않게
이름과 가격이 추가되게 만들려면 어찌해야 할까요..#include stdio.h
#include string.h
#include stdlib.h
#include conio.h
int get_table(void);
void table(void);
void table_switch(int i);
void table_a(int num);
void order(int num);
void payment(int num);
struct menua
{
char anju[30];
int price;
};
struct menus
{
char sul[20];
int price;
};
struct table
{
struct menua sanju;
struct menus ssul;
};
struct menua menua_[4] = {{주문한 안주 없음, 0}, {김치찌개, 13000}, {부대찌개, 15000}, {생태찌개, 16000}};
struct menus menus_[4] = {{주문한 주류 없음, 0}, {좋은데이, 3000}, {시원소주, 3000}, {참이슬, 3000}};
struct table stable[6];
void main(void)
{
int choice;
while(1) {
choice = get_table();
table(choice-1);
}
}
int get_table(void)
{
int i;
char str[3];
int table_sum[6];
for(i = 0; i 6; i++) {
table_sum[i] = stable[i].sanju.price + stable[i].ssul.price;
}
system(cls);
printf(==========================================================================\n);
printf( 술집\n);
printf(==========================================================================\n);
printf(전체 테이블\n);
printf(==========================================================================\n);
printf(■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■\n);
printf(■ ■ ■ ■\n);
printf(■ ■ ■ ■\n);
printf(■ 1번 테이블 ■ 2번 테이블 ■ 3번 테이블 ■\n);
printf(■ %10d원 ■ %10d원 ■ %10d원 ■\n, table_sum[0], table_sum[1], table_sum[2]);
printf(■ ■ ■ ■\n);
printf(■ ■ ■ ■\n);
printf(■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■\n);
printf(■ ■ ■ ■\n);
printf(■ ■ ■ ■\n);
printf(■ 4번 테이블 ■ 5번 테이블 ■ 6번 테이블 ■\n);
printf(■ %10d원 ■ %10d원 ■ %10d원 ■\n, table_sum[3], table_sum[4], table_sum[5]);
printf(■ ■ ■ ■\n);
printf(■ ■ ■ ■\n);
printf(■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■■\n\n);
do{
printf(테이블 번호를 입력해 주세요 (1~6) : );
gets(str);
i = atoi(str);
} while(i1 || i6);
return i;
}
void table(int num)
{
int i;
char str[3];
system(cls);
table_a(num);
do {
printf(수행하실 작업을 입력해 주세요 (1~3) : );
gets(str);
i = atoi(str);
} while(i 1 || i 3);
table_switch(num, i);
}
void table_switch(int num, int i)
{
switch(i) {
case 1 : order(num);
break;
case 2 : payment(num);
break;
case 3 : get_table(num);
break;
}
}
void table_a(int num)
{
printf(==========================================================================\n);
printf( 술집\n);
printf(==========================================================================\n);
printf( %d번 테이블\n,num+1);
printf(==========================================================================\n);
printf(■■■■■■■■■■■■■■■■■■■■■■■■■■■\n);
printf(■ ■ sp; ■\n);
printf(■ ■ ■\n);
printf(■ ■ ■\n);
printf(■ ■ ■\n);
printf(■ 1. 메뉴주문 ■%16s %6d원\n, stable[num].sanju.anju, stable[num].sanju.price);
printf(■ 2. 계산 ■%16s %6d원\n, stable[num].ssul.sul, stable[num].ssul.price);
printf(■ ■총액 %18d원\n, stable[num].sanju.price + stable[num].ssul.price);
printf(■ ■\n);
printf(■ 3. 돌아가기 ■\n);
printf(■ ■\n);
printf(■ ■\n);
printf(■ ■\n);
printf(■ ■\n);
printf(■■■■■■■■■■■■■\n\n);
}
void order(int num)
{
int m, n;
char str[3];
printf(\n주문할 메뉴를 선택해주세요\n);
printf(1. 안주류 2. 주류\n);
printf( );
gets(str);
m = atoi(str);
if(m == 1){
printf(\n주문할 안주를 선택해주세요\n);
do {
printf(1. 김치찌개 2. 부대찌개 3. 생태찌개\n);
printf( );
gets(str);
n = atoi(str);
} while(n 1 || n 3);
switch(n) {
case 1 :
stable[num].sanju=menua_[1];
break;
case 2 :
stable[num].sanju=menua_[2];
break;
case 3 :
stable[num].sanju=menua_[3];
break;
}
}
else if(m == 2) {
printf(\n주문할 소주를 선택해주세요\n);
do {
printf(1. 좋은데이 2. 시원소주 3. 참이슬\n);
printf( );
gets(str);
n = atoi(str);
} while(n 1 || n 3);
switch(n) {
case 1 :
stable[num].ssul = menus_[1];
break;
case 2 :
stable[num].ssul = menus_[2];
break;
case 3 :
stable[num].ssul = menus_[3];
break;
}
}
}
void payment(int num)
{
file *fp;
printf(\n\n계산서\n\n);
printf(%s %d원\n, stable[num].sanju.anju, stable[num].sanju.price);
printf(%s %d원\n, stable[num].ssul.sul, stable[num].ssul.price);
printf(총액 : %d원\n, stable[num].sanju.price + stable[num].ssul.price);
fp = fopen(data.txt, a);
fprintf(fp, \n\n계산서\n%d번 테이블\n%s %d원\n%s %d원\n총액 : %d원, num, stable[num].sanju.anju, stable[num].sanju.price, stable[num].ssul.sul, stable[num].ssul.price, stable[num].sanju.price+stable[num].ssul.price);
fclose(fp);
stable[num].sanju = menua_[0];
stable[num].ssul = menus_[0];
getch();
}
-
PinkPearl
메인함수가 어딨는지 못찾는 건 내 눈이 이상한건가... ㅡ_ㅡ ;;
정확하게 안봐서 도움이 될지는 모르겠지만....
안주가 1개라면 변수를 하나만 써도 되겠지만
2개이상이라면 배열을 쓰면 편하게 관리가 가능합니다.
a를 배열, a_cnt를 a가 현재 가진 수량이라고 할때
a[a_cnt] = val
a_cnt++
를 하게되면 a의 새로운 공간에 새로운 변수(안주)의 추가가 가능하구요.
0~a_cnt-1까지가 현재 a가 가지고 있는 안주의 종류가 됩
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2654881 | PID 모듈 검색 부분 질문합니다 . | 이름없음 | 2024-05-14 |
2654850 | 조건에 만족하는 다음 수를 찾고 싶습니다. | 초엘 | 2024-05-14 |
2654790 | 두파일간 byte단위 txt파일 복사 中 | 슬찬 | 2024-05-14 |
2654768 | 사전만들기 입니다. | 여우By | 2024-05-13 |
2654716 | c언어 고수님들 답좀적어주세요 급합니다 ㅠㅠ | 한말글 | 2024-05-13 |
2654688 | c언어 ㅠㅠ 너 무 어려 워요 ㅠ 도와주세요!! | 별빛 | 2024-05-13 |
2654659 | 구구단 소스 궁금한 점 도움 부탁드립니다! (2) | 미련곰팅이 | 2024-05-12 |
2654633 | 오류가 무었인가요..? (2) | 단순랩퍼 | 2024-05-12 |
2654603 | 어디가 잘못된지를 모르겠습니다. 한 번 봐주세요...ㅠ (2) | 글고운 | 2024-05-12 |
2654574 | 소스 추가좀 부탁드립니다. (등수 출력) | 크리미걸 | 2024-05-12 |
2654550 | 피보나치수열. (3) | 중독적 | 2024-05-11 |
2654521 | c초보 빙고관련게임... | 달콤이 | 2024-05-11 |
2654491 | 10진수를 2진수로 바꾸는법 (8) | 아잉 | 2024-05-11 |
2654412 | 빅오를 구하고 싶어요~ | 애기 | 2024-05-10 |
2654381 | 혼자 연구하는 c/c++ 질문 | 아잉 | 2024-05-10 |
2654352 | 행렬크기를 scanf로 입력받을수도 있나요..? | VanilLa | 2024-05-10 |
2654293 | 첫시작값과 끝값의 사이에 존재하는 정수들의 합을 구하는 것 (5) | 해긴 | 2024-05-09 |
2654185 | 64bit 환경에서 자료형의 크기가 좀궁그해요(완료) 더궁금한게 생겻어요(추가) (2) | 빈길 | 2024-05-08 |
2654152 | 확장자 exe로 변경 (1) | 한 | 2024-05-08 |
2654128 | c언어 간단하게 자판기만들려는데 ㅜㅜ | 유1혹 | 2024-05-08 |