마지막 질문...
유우
질문 제목 : 마지막 질문
코드 추가 방법
질문 내용 :
제가 밑의 코드로코딩중인데요
지금 프로그램에서는 메뉴를 주문할때 안주 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가 가지고 있는 안주의 종류가 됩
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2694590 | 이 코드가 뭐하는 코드일까요? #2 | 빵순 | 2025-05-12 |
2694559 | 동적할당으로 배열(2차원열)을 만드는데 있어 그걸 함수화시키는데... (1) | 늘솔길 | 2025-05-12 |
2694532 | 네트워크에 관하여... (4) | 황소자리 | 2025-05-12 |
2694503 | 프로그램 연산 후 바로 종료되는 현상 (6) | Judicious | 2025-05-11 |
2694450 | while문질문입니다. (1) | 허리품 | 2025-05-11 |
2694420 | C언어 질문할게요(유니코드,자료형,버퍼,캐스트연산자) | 은새 | 2025-05-11 |