연결리스트, 파일처리 help요
솔찬
파일을 저장하면 맨 밑에 사진처럼 나와요 ㅠㅠ 해결 방법좀요 ㅠㅠ
답변은 꼭 실행해 보시고 올려주세요;;;^^수정 해줬는데 안되면 미워할꺼임~^^
질문 내용 :
#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;
}
파일을 저장하면 사진처럼 나와요 ㅠㅠ 해결 방법좀요 ㅠㅠ
답변은 꼭 실행해 보시고 올려주세요;;;^^수정 해줬는데 안되면 미워할꺼임~^^
-
마리
구조체를 바이너리로 저장하셔서 그런것이니, 변수를 각각 저장해보세요.
본인이 짠 소스면 충분히 바꾸실수 있을겁니다.
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |