수다닷컴

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

링크드리스트, 동적 활당을 이용한 전화번호부

김예쁨

2023.04.01

#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언어 입문한지 얼마 되지 안았습니다.그래서 최대한 익힌것을 활용해서 전화관리부를 만들어 봤는데요링크드리스트 삭제와 불러오기가 애러가 납니다.좀 도와주세요 아무리 파고 들어도 해법이 안나옵니다

신청하기





COMMENT

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

  • 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
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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