수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

구조체 와 파일시스템 관련 좀 물어볼려고합니다.

날샘

2023.04.01

#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;
}

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

번호 제 목 글쓴이 날짜
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
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com