링크드리스트, 동적 활당을 이용한 전화번호부
김예쁨
#include stdio.h
#include stdlib.h
#include string.htypedef struct phonenumber{
int idx;
char name[10];
char num[12];
struct phonenumber *link;
}pns;pns* pn;
pns* tmp;
int d=0;//링크드리스트 삭제 함수
void del(int c){
if( c == 1) {
free(&pn[0]);
}
else {pn[c-2].link = &pn[c];
free(&pn[c-1]);
}
d--;
}int main(){
int ch,c=0,i=0;
FILE *f;
while(1){
printf(======\n);
printf(1.입력\n);
printf(2.출력\n);
printf(3.수정\n);
printf(4.삭제\n);
printf(5.저장\n);
printf(6.불러오기\n);
printf(7.종료\n);
printf();
scanf(%d,&ch);
fflush(stdin); switch(ch){
case 1 : //입력 : 동적활당을 이용해서 계속해서 입력할 수 있게 만듬
if( d == 0) pn = (pns*)malloc(sizeof(pns));
else pn = (pns*)realloc(pn,sizeof(pns)*(1+d));
printf(순 서 : %d\n,d+1);
pn[d].idx=d;
printf(이 름 : );
gets(pn[d].name);
printf(전화번호 : );
gets(pn[d].num);
if(d 0) pn[c].link = &pn[d];
pn[d].link = NULL;
c=d;
d++;
break; case 2 : //출력 : 링크드리스트를 이용해 출력 위아래 tmp는 한번 출력후 상주된 메모리가 날라가는 것을 막음
printf(순 서 이 름 전화번호\n);
tmp = pn;
while(pn != NULL){
printf(%8d%10s%16s\n,pn[0].idx+1,pn[0].name,pn[0].num);
pn = pn[0].link;
}
pn = tmp;
break;
case 3 : //수정 : 동적활당된 구조체안에 내용물마 변경
printf(수정할 번호를 선택하세요);
scanf(%d,&c);
fflush(stdin);
tmp = (pns*)malloc(sizeof(pns));
printf(이 름 : );
gets(tmp[0].name);
printf(전화번호 : );
gets(tmp[0].num);
for(i=0;i10;i++){
pn[c-1].name[i] = tmp[0].name[i];
pn[c-1].num[i] = tmp[0].num[i];
}
free(tmp);
break; case 4 : //링크드리스트 방식으로 삭제하려고 하지만 삭제가 안됩니다
printf(삭제 할 번호를 입력하세요 );
scanf(%d,c);
del(c);
case 5 ://저장 : 전화번호부를 저장합니다.
f=fopen(d:\\phone.txt,wb);
fputc(c,f);
for(i=0;id;i++){
fwrite((void*)&pn[i], sizeof(pn[i]),i,f);
}
fclose(f);
break; case 6 : //불러오기 : 불러오기를 하면 맨처음 데이터만 불러와지고 애러가 나버립니다
f=fopen(d:\\phone.txt,rb);
c=fgetc(f);
for(i=0;i=c;i++){
if( i == 0) pn = (pns*)malloc(sizeof(pns));
else pn = (pns*)realloc(pn,sizeof(pns)*(1+i));
}
for(i=0;i=c;i++){
fread((void*)&pn[i], sizeof(pn[i]),i,f);
}
fclose(f);
break; case 7 :
return 0;
default :
printf(잘못 입력 하셨습니다.\n);
}
}
}=======================================================================================c언어 입문한지 얼마 되지 안았습니다.그래서 최대한 익힌것을 활용해서 전화관리부를 만들어 봤는데요링크드리스트 삭제와 불러오기가 애러가 납니다.좀 도와주세요 아무리 파고 들어도 해법이 안나옵니다
-
Emily
아까는 제가 돌려볼 수가 없어서.. ;;; 제가 했던 연결리스트와 동적할당 스타일과 좀 달라서...
아집이 생겼나 봅니다. 제가 아는게 세상의 전부인양 ..;;; 죄송합니다.
근데 이런식으로도 가능하군요 흠... 새로 알았습니다. 감사합니다. -
요루
링크드리스트가 삭제가 배열처럼 보이는 것은 동적 활당 때문입니다 pn이라는 변수는 동적 활당 변수이구요
소스를 이해 못하신듯 하네요 프로그램 동작에는 문제가 없습니다 특정 부분에서 에러가 나는 것입니다
소스부터 이해 해주세요 -
하린
삭제하는 부분을 구현하는 곳을 보니 연결리스트로 삭제하신다고 하셔놓고 배열을 사용하셨네요?
그리고 불러오기 부분도 마찬가지로 정확히 텍스트파일을 열어서 프로그램에서 어떻게 자료를 받아들이는지 파악이 안된 것 같습니다.
동적 할당을 사용해서 저장을 해야 하는 것은 인지하셨는데 어떻게 하셔야 할지도 모르시는 것 같구요. ( 도대체 \pn\이라는 변수는 어디에서 나온 변수인가요? 당최 알수가 없네요 ;;)
연결리스트에 대한 개념을 아직 못 잡으신 것 같
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2694929 | 열혈강의 25-2 두번째 문제 질문 | 지우개 | 2025-05-15 |