다시질문드리겟습니다 자판기입니다.
보슬
질문 제목 : 질문 내용 :
문법사항.흐름같은것좀알려주세요
주석도달아주실수잇으면..ㅠㅠㅠㅠㅠㅠ
#include stdio.h
#include stdlib.h
#include string.h
#include time.h
#include windows.h
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
typedef struct daysell // 구조체 선언
{
int year; //년도
int mon; //월
int day; //일
}day;
typedef struct data{
char name[20];
int price;
int count;
struct data* next;
}data;
data* head;
data* tail;
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void init();
void data_menu(); //메뉴선택화면
void data_select1(); //물품구매모드
void choice_food();//음식선택
void sell_list(); //구매물품목록 읽기
void sell(); //계산
void day_sell(); //일일정산함수
void daysell_load(); //일일정산불러오기
void daysell_print(int); //일일정산출력
void data_select2(); //관리자모드
void data_delete(); //물품삭제
void data_search(); //데이터 검색
void insert_select(); //품목별 품목추가
void save();
void food_save();//음식저장
void load_select(); //품목별 물품조회
void food_load(); //음식조회
void delete_select(); //품목별 물품삭제
void food_del(); //음식삭제
void node_deleteall();
void data_print(); //물품출력
void node_print(data* p);
void head_print();
void tail_print();
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
int main(){
init();
data_menu();
return 0;
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void init(){
head = (data*)malloc(sizeof(data));
tail = (data*)malloc(sizeof(data));
head-next = tail;
tail-next = tail;
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void data_menu(){
int choice;
do{
printf(\t\t\t********menu********\n);
printf(\t\t\t1. (자판기판매시작) \n);
printf(\t\t\t2. (자판기관리모드) \n);
printf(\t\t\t0. (자판기 종료) \n);
printf(\t\t\t********************\n\n\n);
printf(\t\t\t choice (선택) [ ]\b\b\b);
scanf(%d,&choice);
switch(choice){
case 1: system(cls); data_select1(); break;
case 2: system(cls); data_select2(); break;
case 0: system(cls); printf(\n\n\n\n\t\t\t*자판기전원을 종료합니다*\n\n\n\n\n\n\n\n);
}
}while(choice != 0);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void data_select1()
{
int choice;
do
{
printf(\t\t\t***** 구매할목록 *****\n\n);
printf(\t\t\t 1. 음식구매 \n);
printf(\t\t\t 2. 과자구매 \n);
printf(\t\t\t 3. 음료구매 \n);
printf(\t\t\t&nbsbsp; 4. 빙과구매 \n);
printf(\t\t\t 5. 주류구매 \n);
printf(\t\t\t 6. 총 계산 \n);
printf(\t\t\t 0. 메 인 \n\n);
printf(\t\t\t***********************\n\n\n);
printf(\t\t\t choice (선택) [ ]\b\b\b);
scanf(%d,&choice);
switch(choice){
case 1: system(cls); choice_food(); break;
case 6: system(cls); sell(); break;
case 0: system(cls); break;
}
}while(choice != 0);
}
/////////////////////////////////////////////////////////////////////////////////////////////
void choice_food()
{
food_load(); data_print();
data* p;
p = head-next;
char find_name[20];
file *file;
printf(선택할 물품 : );
scanf(%s,find_name);
while(p != tail){
if(strcmp(find_name, p-name) == 0)
break;
else
p = p-next;
}
if(p == tail)
printf(입력한 물품 %s는 존재하지 않습니다.\n,find_name);
else{
printf(구매할 수량 : );
scanf(%d, &p-count);
printf(%5s ,p-name);
printf(%d원 ,p-price);
printf(%d개\n,p-count);
file=fopen(./sell.txt, a);
fprintf(file,%s %d %d\n,p-name, p-price, p-count);
fclose(file);
printf(선택한 물품을 구매목록에 담았습니다.\n);
}
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void sell_list() //구매선택한 물품
{
file *file;
data *p;
file=fopen(./sell.txt,r);
if(file == null){
printf(물품이 없습니다.\n);
return;
}
else
{
printf(== 구매선택한 물품 ==\n);
p = (data*)malloc(sizeof(data));
node_deleteall();
while((fscanf(file,%s%d%d, p-name, &p-price, &p-count)) != -1){
p-next = head-next;
head-next = p;
p = (data*)malloc(sizeof(data));
}
data_print();
}
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void sell()
{
int sum=0, money=0;
int choice, price, count;
file *file;
data *p;
file=fopen(./sell.txt,r);
if(file == null){
printf(물품이 없습니다.\n);
return;
}
else
{
printf(== 구매선택한 물품 ==\n);
p = (data*)malloc(sizeof(data));
node_deleteall();
while((fscanf(file,%s%d%d, p-name, &p-price, &p-count)) != -1){
p-next = head-next;
head-next = p;
sum+=(p-price * p-count);
p = (data*)malloc(sizeof(data));
}
data_print();
}
fclose(file);
printf(총 계산 금액 : %d\n, sum);
while (1)
{
printf(계산 금액을 지불하시오 : );
scanf(%d, &money);
if (moneysum)
printf(금액이 부족합니다. 다시 입력하시오.\n);
else if (money==sum)
{
printf(계산되었습니다. 감사합니다\n);
day_sell();
break;
}
else
{
printf(계산되었습니다. 감사합니다.\n);
printf(거스름돈 : %d\n, money-sum);
day_sell();
break;
}
}
file=fopen(./sell.txt,w);
fclose(file);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void day_sell()
{
day date;
///////////////////////////////
time_t times;
struct tm *ti;
time(×);
ti=localtime(×);
///////////////////////////////
date.year = ti-tm_year+1900;
date.mon = ti-tm_mon+1;
date.day = ti-tm_mday;
file *file, *file_daysell;
data *p;
int sum=0;
file=fopen(./sell.txt,r);
if(file == null)
return;
else
{
p = (data*)malloc(sizeof(data));
node_deleteall();
while((fscanf(file,%s%d%d, p-name, &p-price, &p-count)) != -1){
p-next = head-next;
head-next = p;
sum=(p-price * p-count);
file_daysell=fopen(./day_sell.txt, a);
fprintf(file_daysell, %d %d %d , date.year,date.mon, date.day);
fprintf(file_daysell,%s %d %d %d\n,p-name, p-price, p-count, sum);
p = (data*)malloc(sizeof(data));
}
}
fclose(file);
fclose(file_daysell);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void data_select2(){
int choice;
do{
printf(\t\t\t***** 관리자모드 *****\n\n);
printf(\t\t\t 1. 물품추가 \n);
printf(\t\t\t 2. 물품조회 \n);
printf(\t\t\t 3. 물품삭제 \n);
printf(\t\t\t 4. 일일정산 \n);
printf(\t\t\t 0. 메 인 \n\n);
printf(\t\t\t***********************\n\n\n);
printf(\t\t\t choice (선택) [ ]\b\b\b);
scanf(%d,&choice);
switch(choice){
case 1: insert_select(); break;
case 2: load_select(); break;
case 3: delete_select(); break;
case 4: daysell_load(); break;
case 0: system(cls); break;
}
}while(choice != 0);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void insert_select(){
system(cls);
int choice;
do{
printf(\t\t\t***** 물품추가 *****\n\n);
printf(\t\t\t 1. 음식추가 \n);
printf(\t\t\t 2. 과자추가 \n);
printf(\t\t\t 3. 음료추가 \n);
printf(\t\t\t 4. 빙과추가 \n);
printf(\t\t\t 5. 주류추가 \n);
printf(\t\t\t 0. 상위메뉴 \n);
printf(\t\t\t***********************\n\n\n);
printf(\t\t\t choice (선택) [ ]\b\b\b);
scanf(%d,&choice);
switch(choice){
case 1: init(); save(); food_save(); system(cls); break;
case 0: system(cls); break;
}
}while(choice != 0);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void save(){
data* p;
data* q;
q = head-next;
p = (data*)malloc(sizeof((sizeof(data));
printf(물품명 : );
scanf(%s,p-name);
printf(가격 : );
scanf(%d,&p-price);
printf(수량 : );
scanf(%d,&p-count);
p-next = head-next;
head-next = p;
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void food_save() {
file* file;
data* p;
p = head-next;
file = fopen(food.txt, a);
while(p != tail){
fprintf(file,%s ,p-name);
fprintf(file,%d ,p-price);
fprintf(file,%d ,p-count);
p = p-next;
}
fclose(file);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void load_select(){
system(cls);
int choice;
do{
printf(\t\t\t***** 물품조회 *****\n\n);
printf(\t\t\t 1. 음식조회 \n);
printf(\t\t\t 2. 과자조회 \n);
printf(\t\t\t 3. 음료조회 \n);
printf(\t\t\t 4. 빙과조회 \n);
printf(\t\t\t 5. 주류조회 \n);
printf(\t\t\t 6. 전체조회 \n);
printf(\t\t\t 0. 상위메뉴 \n\n);
printf(\t\t\t***********************\n\n\n);
printf(\t\t\t choice (선택) [ ]\b\b\b);
scanf(%d,&choice);
switch(choice){
case 1: system(cls); printf(음식\n); food_load(); data_print(); break;
case 0: system(cls); break;
}
}while(choice != 0);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void food_load(){
file* file;
data* p;
file = fopen(./food.txt,r);
if(file == null){
printf(물품이 없습니다.\n);
return;
}
p = (data*)malloc(sizeof(data));
node_deleteall();
while((fscanf(file,%s%d%d, p-name, &p-price, &p-count)) != -1){
p-next = head-next;
head-next = p;
p = (data*)malloc(sizeof(data));
}
fclose(file);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void node_deleteall(){
data* p;
data* q ;
q = head;
p = q-next;
while(p != tail){
q-next = p-next;
free(p);
p = q-next;
}
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void data_print(){
data* p;
p = head-next;
if(p == tail){
printf(물품이 없습니다.\n);
return;
}
head_print();
while(p != tail){
node_print(p);
p = p-next;
}
tail_print();
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void node_print(data* p){
printf(%10s\t,p-name);
printf(%d\t,p-price);
printf(%d\n,p-count);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void delete_select(){
system(cls);
int choice;
do{
printf(\t\t\t***** 물품삭제 *****\n\n);
printf(\t\t\t 1. 음식삭제 \n);
printf(\t\t\t 2. 과자삭제 \n);
printf(\t\t\t 3. 음료삭제 \n);
printf(\t\t\t 4. 빙과삭제 \n);
printf(\t\t\t 5. 주류삭제 \n);
printf(\t\t\t 0. 상위메뉴 \n);
printf(\t\t\t***********************\n\n\n);
printf(\t\t\t choice (선택) [ ]\b\b\b);
scanf(%d,&choice);
switch(choice){
case 1: system(cls); food_load(); data_print(); food_del(); break;
case 0: system(cls); break;
}
}while(choice != 0);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void food_del(){
food_load();
data* p; //삭제할 노드
data* q;//삭제하기위한 앞노드
char find_name[20];
q = head;
p = q-next;
printf(삭제할 이름 입력 : );
scanf(%s,find_name);
while(p != tail){
if(strcmp(find_name, p-name) == 0){
break;
}else{
q = q-next;
p = q-next;
}
}
if(p == tail){
printf(입력한 이름 \ %s \는 존재하지 않습니다.\n,find_name);
}else{
q-next = p-next;
free(p);
printf(입력한 이름 \ %s \를 삭제 했습니다.\n,find_name);
}
file *file;
file=fopen(cookie.txt, w);
fclose(file);
food_save();
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void head_print(){
printf(==================================\n);
printf( 이름\t가격\t수량\n);
printf(==================================\n);
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void tail_print(){
printf(==================================\n\n);
}
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
void daysell_load()
{
int sum=0;
file* file;
data* p;
day date;
data data;
time_t times;
struct tm *ti;
time(×);
ti=localtime(×);
date.year = ti-tm_year+1900;
date.mon = ti-tm_mon+1;
date.day = ti-tm_mday;
file = fopen(./day_sell.txt,r);
system(cls);
printf( ===================================\n);
printf( 날짜\t이름\t가격\t판매수량\n);
printf( ===================================\n);
if(file == null ||sizeof(file)1)
{
printf(물품이 없습니다.\n\n\n\n);
return;
}
else
if((fscanf(file,%d%d%d%s%d%d, &date.year, &date.mon, &date.day, data.name, &data.price, &data.count)) != -1)
{
sum=(data.price * data.count);
printf(%10d %8s %6d %10d \n, date.year, datear, data.name, data.price, data.count );
printf(총계 : %d\n,sum);
}
}
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |