구조체 와 파일시스템 관련 좀 물어볼려고합니다.
날샘
#includestdio.h
#includestdlib.h
#includestring.h
// 도서 구조체;
struct dosu {
char name[100]; //도서 이름
int number; // 책 넘버
long int isbn; // isbn
char cricname[30]; //저자
struct dosu *edong; //포인터
}*head = null;
struct dosu *question(struct dosu *newb); // 질문
struct dosu *insert(struct dosu *temp, struct dosu *newb); //삽입.
struct dosu *beetween(void);
int save(struct dosu *temp);
struct dosu *open(void);
void search (void);
void delet(void);
//사이에 삽입 하기
void printlist(void);
int main(void)
{
int i;
struct dosu *temp;
struct dosu news;
temp=head;
do{
printf(------------------------------------\n);
printf(1.도서를 검색하시겠습니까?\n);
printf(2.도서품목을 증가하시겠습니까?\n);
printf(3.도서품목 사이에 도서품목을 증가시키겠습니까?\n);
printf(4.모든 항목 보기\n);
printf(5.도서품목을 삭제하시겠습니까?\n);
printf(6.저장하시겠습니까?\n);
printf(7.불러오시겠습니까?\n);
printf(8. exit\n);
printf(------------------------------------\n);
printf(\n);
printf(번호를 선택하여 주십시요 : );
scanf(%d, &i);
if(i==1)
{
if(head==null)
{
printf(아무런 데이터가 없습니다. 데이터를 먼저 삽입 해주세요.\n);
}
else
{
search();
}
}
else if(i==2)
{
question(&news);
temp=insert(temp, &news);
}
else if(i==3)
{
if(head==null)
{
printf(아무런 데이터가 없습니다. 데이터를 먼저 삽입 해주세요.\n);
}
else
{
temp=beetween();
}
}
else if(i==4)
{
if(head==null)
{
printf(아무런 데이터가 없습니다. 데이터를 먼저 삽입 해주세요.\n);
}
else
{
printlist();
}
}
else if(i==5)
{
if(head==null)
{
printf(아무런 데이터가 없습니다. 데이터를 먼저 삽입 해주세요.\n);
}
else
{
delet();
}
}
else if(i==6)
{
if(head==null)
{
printf(아무런 데이터가 없습니다. 데이터를 먼저 삽입 해주세요.\n);
}
else
{
save(temp);
}
}
else if(i==7)
{
temp=open();
}
else if(i==8)
{
break;
}
else
{
printf(없는 번호입니다. 다시 선택하여 주시기 바랍니다.\n);
}
}while(i!=8);
}
//질문
struct dosu *question(struct dosu *newb)
{
printf(책의 이름을 써넣어 주십시요:);
scanf(%s, &newb-name);
printf(지정될 책의 번호를 삽입 해주세요 : );
scanf(%d, &newb-number);
printf(isbn을 써넣어 주십시요 :);
scanf(%d, &newb-isbn);
printf(저자의 이름을 써넣어 주십시요:);
scanf(%s, &newb-cricname);
return newb;
}
//삽입부
struct dosu *insert(struct dosu *temp, struct dosu *newb)
{
struct dosu *i;
i=(struct dosu*)malloc(sizeof(struct dosu));
strcpy(i-name, newb-name);
i-number = newb-number;
i-isbn = newb-isbn;
strcpy(i-cricname, newb-cricname);
if(head==null)
{
head=i;
i-edong=null;
}
else
{
i-edong=temp-edong;
temp-edong = i;
}
return i;
}
//사이삽입.
struct dosu *beetween(void)
{
int bob;
struct dosu *po, *ba;
struct dosu bo;
po=ba=head;
printf(책의 어떤 번호에다가 삽입 하시겠습니까?);
scanf(%d, &bob);
question(&bo);
if(head-number==bob)
{
if(head-number==bo.number)
{
printf(지정된 번호가 앞에 있습니다.\n);
}
else if(head-number!=bo.number)
{
insert(ba, &bo);
};}
}
else if(head-number!=bob)
{
while(po-edong!=null)
{
po = po-edong;if(po-number==bob)
{
insert(ba, &bo);
po-number++;
while(po-edong!=null)
{
po-number++;
po = po-edong;
}
break;
}
ba=ba-edong;
}
}
return po;
}
//모든항목보기.
void printlist(void)
{
struct dosu *pop;
printf(--------------------------\n);
printf(책의 이름은 %s 입니다.\n, head-name);
printf(책의 지정번호는 %d 입니다.\n, head-number);
printf(책의 isbn은 %d 입니다.\n, head-isbn);
printf(책의 저자는 %s 입니다.\n, head-cricname);
printf(--------------------------\n);
pop=head;
while(pop-edong!=null)
{
printf(--------------------------\n);
pop=pop-edong;
printf(책의 이름은 %s 입니다.\n, pop-name);
printf(책의 지정번호는 %d 입니다.\n, pop-number);
printf(책의 isbn은 %d 입니다.\n, pop-isbn);
printf(책의 저자는 %s 입니다.\n, pop-cricname);
printf(--------------------------\n);
}
}
//삭제
void delet(void)
{
struct dosu *f, *m;
int i;
printf(몇번을 삭제하시겠습니까?);
scanf(%d, &i);
f=m=head;
m=m-edong;
do
{
if(f-number==i)
{
head=head-edong;
break;
}
else if(m-number==i)
{
f-edong = m-edong;
break;
}
f=f-edong;
m=m-edong;
}while(1);
}
//검색부
void search (void)
{
struct dosu *po;
int i;
po=head;
printf(어떤 책을 검색하시겠습니까?(책의 지정번호를 입력해주세요):);
scanf(%d, &i);
if(head-number==i)
{
printf(--------------------------\n);
printf(책의 이름은 %s 입니다.\n, head-name);
printf(책의 지정번호는 %d 입니다.\n, head-number);
printf(책의 isbn은 %d 입니다.\n, head-isbn);
printf(책의 저자는 %s 입니다.\n, head-cricname);
printf(--------------------------\n);
}
else
{
while(po-edong!=null)
{
po=po-edong;
if(po-number==i)
{
printf(--------------------------\n);
printf(책의 이름은 %s 입니다.\n, po-name);
printf(책의 지정번호는 %d 입니다.\n, po-number);
printf(책의 isbn은 %d 입니다.\n, po-isbn);
printf(책의 저자는 %s 입니다.\n, po-cricname);
printf(--------------------------\n);
}
else if(po-number!=i)
{
printf(지정된 번호가 없습니다. 2번 품목에서 책을 추가 해주시기를 바랍니다.\n);
}
}
}
}
//저장
int save(struct dosu *temp)
{
int state;
file *file =fopen(c:\\test.txt, wt);
temp=head;
if(file==null){
printf(에러\n);
return 1;
}
fprintf(file, %s\t%d\t%d\t%s\n, head-name, head-number, head-isbn, head-cricname);
while(temp-edong!=null)
{
temp=temp-edong;
fprintf(file, %s\t%d\t%d\t%s\n, temp-name, temp-number, temp-isbn, temp-cricname);}
state=fclose(file);
if(state!=null){
printf(에러\n);
return 1;
}
return 0;
}
//불러오기
이쪽 불러오기 쪽에서요 텍스트에서 불러온 데이터로 연결리스트로 저장하고싶어서 대충 파일 끝을 조건으로 걸어서 했는데 자꾸 첫번째 데이터는 사라지고 마지막 데이터는 중복이 되서 나타납니다. 이것을 해결할려면 어떻게 해야하나요? 아 그리고 이거 컴파일 할때 워링이 많이 뜨던데;; 그 이유도 같이 알았으면 감사하겠습니다 ㅠㅠ.
struct dosu *open(void)
{
int iov;
struct dosu *i=(struct dosu*)malloc(sizeof(struct dosu));
int state;
file *file =fopen(c:\\test.txt, r);
if(file==null){
printf(에러\n);
return 1;
}
while(1)
{
iov=fgetc(file);
if(iov==-1)
{
break;
}
fscanf(file,%s %d %d %s\n, i-name , &i-number , &i-isbn , i-cricname);
i=insert(i,i);}
state=fclose(file);
if(state!=null){
printf(에러\n);
return 1;
}
return i;
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2695707 | 3의 배수 나타내기. (2) | 수리 | 2025-05-23 |
2695626 | 피보나치수열 과제 때문에 질문 드립니다. (6) | 옆집언니 | 2025-05-22 |
2695595 | 포인트공부중입니다 int형에서 4=1 인가요? (3) | 족장 | 2025-05-22 |
2695567 | 드라이브 고유번호를 가져오는 함수 (2) | 초코맛사탕 | 2025-05-21 |
2695533 | 음수의 산술변환! 질문이요 ㅠㅠ... (4) | 꽃여름 | 2025-05-21 |
2695506 | 구조체 배열 이용 도서목록 출력 프로그램 (1) | 가을귀 | 2025-05-21 |
2695450 | c언어 함수 질문이요.... | 이슬비 | 2025-05-20 |
2695403 | VirtualAlloc함수 및 메모리 질문 | 크리에이터 | 2025-05-20 |
2695355 | c언어 for함수 | 미쿡 | 2025-05-19 |
2695327 | 안녕하세요 제가 이번에 좀 큰 프로그램을.. | 악당 | 2025-05-19 |
2695295 | mutex동기화의 thread기반 채팅 서버소스 질문입니다 | 그루터기 | 2025-05-19 |
2695270 | 질문이요..swap 관한겁니다..ㅠㅠ (3) | 콩알녀 | 2025-05-19 |
2695244 | 노땅초보궁금한게 하나 있는데요..반복문(while문)초보자질문 (6) | 큰꽃늘 | 2025-05-18 |
2695166 | do while 문 어떤것이잘못된건지 모르겠어요 (2) | 아이폰 | 2025-05-18 |
2695122 | 구조체에 대해 물어보고 싶은게 있습니다 ^^^.. (7) | 수련 | 2025-05-17 |
2695091 | txt 파일 입출력 후 2차 배열에 저장하기입니다. (3) | 헛장사 | 2025-05-17 |
2695063 | 수도요금 프로그램좀 짜주세요. | 시내 | 2025-05-17 |
2695033 | 답변좀요ㅠㅠ (1) | 비사벌 | 2025-05-16 |
2695010 | C++의 STL은 왜 굳이 템플릿화 시켜서 라이브러리를 만드나요? (초보수준의 질문..) (2) | 엘보어 | 2025-05-16 |
2694958 | 로직이 변한다는 것에 대해서 궁금합니다. | 튼동 | 2025-05-16 |