수다닷컴

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

연결리스트, 파일처리 help요

솔찬

2023.04.01

파일을 저장하면 맨 밑에 사진처럼 나와요 ㅠㅠ 해결 방법좀요 ㅠㅠ
답변은 꼭 실행해 보시고 올려주세요;;;^^수정 해줬는데 안되면 미워할꺼임~^^
질문 내용 :

#include stdio.h
#include string.h
#include stdlib.h
#include conio.htypedef struct _node{
char name[20];
char x[20];
char y[20];
struct _node *next;
}node;
node *head; //헤드
node *tail; //테일//초기 노드 설정
void init(void)
{
head=(node*)malloc(sizeof(node)); //헤드 노드 동적할당
tail=(node*)malloc(sizeof(node)); //꼬리 노드 동적할당
head-next=tail; //헤드 노드의 포인터를 꼬리 노드에 연결
tail-next=tail; //꼬리 노드의 포인터를 헤드 노드에 연결
}//노드 삽입
void insertafter(char *name, char *x, char *y)
{
node *t;
t=(node*)malloc(sizeof(node)); //삽입 할 노드 생성
strcpy(t-name, name); //노드에 이름 입력
strcpy(t-x, x);
strcpy(t-y, y);
t-next=head-next; //삽입할 노드의 포인터를 헤드 노드의 포인터가 가리키고 있는 노드로 연결. 즉 꼬리 노드에 연결
head-next=t; //헤드 노드의 포인터를 삽입할 노드에 연결
printf(--------data inserted\n);
}//리스트 내용 출력
void printfall(void)
{
node *t;
t=head-next; //첫 노드를 헤드 노드가 가리키고 있는 노드로 설정
if (head-next == tail) //헤드 노드의 포인터가 꼬리 노드를 가리키면 printf문 출력
{
printf(파일이 없습니다.\n\n);
} while (t != tail) //꼬리 노드가 아니면 헤드 노드부터 하나씩 이동하면서 각 노드의 내용 출력
{
printf(name : %s\t coordinate : (%s,%s) \n, t-name, t-x, t-y);
t=t-next;
}}//리스트 삭제
void deleteall(void)
{
node *p;
node *s;
p=head-next; //첫 노드를 헤드 노드가 가리키고 있는 노드로 설정
if (head-next == tail) //헤드 노드의 포인터가 꼬리 노드를 가리키면 printf문 출력
{
printf(삭제할 것이 없습니다.\n\n);
}

while (p != tail) //꼬리노드가 아니면
{
sp;
s=p; //현재 노드를 복사
p=p-next; //다음노드로 이동
free(s); //복사한 노드 반납
}
head-next=tail; //꼬리 노드에 도달하면 printf문 출력
}//노드 탐색
void findnode(char *name)
{
node *t;
t=head-next; //첫 노드를 헤드 노드가 가리키고 있는 노드로 설정
while (t != tail && strcmp(t-name, name) != 0) //노드를 하나씩 거치면서 이름을 비교
{
t=t-next;
}
if (t == tail) //노드가 꼬리 노드에 도달하면 동일한 정보가 없음
{
printf(찾으시는 정보가 없습니다.\n\n);
}
else //같은 이름이 있다면 정보 출력
{
printf(name : %s coordinate : (%s,%s) \n, t-name, t-x, t-y);
}
}//삭제할 노드 검색
void finddelete(char *name)
{
node *p;
node *s;
node *t;
p=head-next; //첫 노드를 헤드 노드가 가리키고 있는 노드로 설정
s=head; //헤드노드
while (p != tail && strcmp(p-name, name) != 0) //노드를 이동하면서 이름을 비교
{
s=s-next;
p=s-next;
}

if (p == tail) //노드가 꼬리 노드에 도달하면 동일한 정보가 없음
{
printf(삭제할 파일이 없습니다.\n\n);
}
else //같은 이름이 있다면
{
t=p; //현재노드 복사
p=p-next; //다음노드로 이동
s-next=p; //전노드의 포인터를 현재노드의 다음 노드를 가리키게함
free(t); //복사한 현재노드 삭제
printf(---------data deleted\n\n);
}
}//노드 저장
void save_node(char *s) //파일로 저장!!
{
file *fp;
node *t;
if ((fp=fopen(s, wb)) == null) //파일 쓰기모드로 염
{
printf( error \n);
return;
}
t=head-next; //첫번째 노드 설정
while (t != tail) //꼬리 노드까지 이동하면서 파일에 씀
{
fwrite(t, sizeof(node)-4, 1, fp);
t=t-next;
}
fclose(fp); //꼬리노드에 도달하면 파일을 닫음
}//파일 읽기
void load_node(char *t) //파일 정보를 연결리스트로!!
{
file *fp;
node *p;
node *s;
if ((fp=fopen(t, rb)) == null) //파일을 읽기모드로 염
{
printf( error \n);
return;
}
p=head-next; //첫번째 노드 설정
while (p != tail) //노드가 꼬리 노드가 될때까지
{
s=p; //현재노드 복사
p=p-next; //다음노드를 가리킴
free(s); //복사한 노드 반납
}
head-next=tail; //헤드 노드의 포인터가 꼬리 노드를 가리킴
while (1)
{
p=(node*)malloc(sizeof(node)); //노드 할당
if (!fread(p, sizeof(node)-4, 1, fp)) //읽을 정보가 없으면 빈 노드 반납, 읽을 정보가 있으면 노드에 저장
{
free(p);
break;
}
p-next=head-next; //현재 노드의 포인터를 헤드 노드가 가리키는 노드를 가리킴
head-next=p; //헤드 노드의 포인터는 현재 노드를 가리킴
}
fclose(fp); //파일을 닫음
}int main(void)
{
char name[20]={0,};
char x[20]={0,};
char y[20]={0,};
int select=0;
char *file = date.txt;
init();
load_node(file); // 시작시 파일 정보 리딩!!!!
while (1)
{
printf(\n\n-----------menu-----------\n);
printf( 1. insert\n);
printf( 2. delete\n);
printf( 3. search\n);
printf( 4. print all\n);
printf( 5. exit\n);
printf(choose the item: );
scanf(%d, &select);

switch(select)
{
case 1:
{
printf([insert]\n);
printf(input name :);
scanf(%s, name);
printf(iput coordinate x: );
scanf(%s, x);
printf(iput coordinate y: );
scanf(%s, y);
insertafter(name, x, y);
break;
}
case 2:
{
printf([delete]\n);
printf(input name :);
scanf(%s, name);
finddelete(name);
break;
}
case 3:
{
printf([search]\n);
printf(input name :);
scanf(%s, name);
findnode(name);
break;
}
case 4:
{
printf([print all]\n);
printfall();
break;
}
case 5:
{
save_node(file); // 종료시 파일로 저장!!
deleteall();
exit(0);
}
default:
{
printf(잘못 누르셨습니다.\n);
break;
}
}
getch();
system(cls);
}
deleteall();
free(head);
free(tail);
return 0;
}

파일을 저장하면 사진처럼 나와요 ㅠㅠ 해결 방법좀요 ㅠㅠ
답변은 꼭 실행해 보시고 올려주세요;;;^^수정 해줬는데 안되면 미워할꺼임~^^

신청하기





COMMENT

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

  • 마리

    구조체를 바이너리로 저장하셔서 그런것이니, 변수를 각각 저장해보세요.
    본인이 짠 소스면 충분히 바꾸실수 있을겁니다.

번호 제 목 글쓴이 날짜
2694503 프로그램 연산 후 바로 종료되는 현상 (6) Judicious 2025-05-11
2694450 while문질문입니다. (1) 허리품 2025-05-11
2694420 C언어 질문할게요(유니코드,자료형,버퍼,캐스트연산자) 은새 2025-05-11
2694370 내일까진데 함수호출 제발 도와주세요!!!!!!!!!11 들찬 2025-05-10
2694339 putchar()의 괄호 안에 int c=10;로 전에 선언된 c를 넣으면 안되는 이유에서 제가 생각한 것이 그 이유가 되는지 확인하고 싶습니다. (3) 미르 2025-05-10
2694316 이 코드 어디가 잘못되었는지 고수분들 ㅠㅠ (2) 나빛 2025-05-10
2694285 언어 공부하는 과정 좀 추천해주세요! (1) 아빠몬 2025-05-09
2694258 카운터.. 질문입니다. (4) 하늘빛눈망울 2025-05-09
2694229 단순한 질문이요 (8) 여름 2025-05-09
2694202 용돈을 가지고 할 수 있는 일을 여러가지로 출력하는 방법 좀 알려주세요! (2) 미나 2025-05-09
2694145 화면깜빡임을 없애고 싶은데요... (1) 어서와 2025-05-08
2694069 unsigned 질문입니다. 힘차 2025-05-07
2694012 전공 비전공자 개발자 (10) 말글 2025-05-07
2693984 오버로딩이 무엇인가요? (2) 헛매질 2025-05-07
2693956 PlaySound재생이 안됩니다!(C에 음악넣기) 지존 2025-05-06
2693928 &와 *의 사용에 관한 명확한 이해 제나 2025-05-06
2693903 반복문 설명좀요 ㅠㅠ (2) 란새 2025-05-06
2693869 stdio.h 는 왜 쓰는건가요? (1) 큰꽃들 2025-05-06
2693842 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) 진솔 2025-05-05
2693811 소수 출력;;;; 화이트캣 2025-05-05
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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