마지막 질문...
유우
질문 제목 : 마지막 질문
코드 추가 방법
질문 내용 :
제가 밑의 코드로코딩중인데요
지금 프로그램에서는 메뉴를 주문할때 안주 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가 가지고 있는 안주의 종류가 됩
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |