수다닷컴

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

이진탐색트리 디스크 기반??

앤드류

2023.04.01

질문 제목 : 질문 내용 :이진탐색트리를 디스크 기반으로 짜오라는데 먼말인지 잘 모르겟네여 ㅜㅜ

#include stdio.h
#include string.h
#define yes 1
#define no 0
#define list struct list list {
char *name;
char *tel;
list *left;
list *right;
}; void main() {
list *root, *insert(), *srch(), *modi(), *delet(), *temp;
char name[15], tel[15];
char cname[15];
int key;
void prnt(), inp();
file *fp; root=null; do {
printf(\ninput(file)-1, input(keyboard)-2, display-3, search-4, update-5, delete-6, end-7);
printf(select a key ---);
scanf(%d, &key);
if(key==1) {
printf(\n---input---\n);
fp=fopen(binary.dat, r);
if(fp != null)
while(fscanf(fp, %s %s, name, tel) != eof) {
printf(name=%s tel=%s\n, name, tel);
root=insert(root, name, tel);
&n}
else
printf(fopen error\n);
}
if(key==2) { //키보드에서 삽입할 데이터값을 입력받음
inp(name, tel);
root=insert(root, name, tel);
}
if(key==3) {
printf(\n---display---\n);
printf(\nlevel name tel \n);
prnt(root, 1);
}
if(key==4) {
printf(\n---search---\n);
printf( name--- );
scanf(%s, cname);
temp=srch(root, cname);
}
if(key==5) {
printf(\n---update---\n);
printf( name--- );
scanf(%s, cname);
modi(root, cname);
}
if(key==6) {
printf(\n---delete---\n);
printf( name--- );
scanf(%s, cname);
root=delet(root, cname);
}
if(key==7) {
printf(\n---end---\n);
}
} while(key7);
} //재귀적으로 트리를 순회하면서 입력위치를 결정
list *insert(list *rp, char *name, char *tel) {
list *create_node();
char *strsv();
int cmp; if(rp==null) { //트리가 비어있는 상태
rp=create_node(); //하나의 노드를 할당받아
rp-name=strsv(name); //데이터 필드와 연결필드를 설정
rp-tel=strsv(tel);
rp-left=rp-right=null;
}
else if((cmp=strcmp(name, rp-name))==0) { //이미 데이터가 존재할 때
printf(\n------------------------\n);
printf(name=%-15s tel=%-13s \n, rp-name, rp-tel);
printf(\n------------------------\n);
}
else if(cmp 0) //왼쪽 부트리로 이동
rp-left=insert(rp-left, name, tel);
else
rp-right=insert(rp-right, name, tel);
return(rp);
} void inp(char *name, char *tel) {
printf(name--- );
scanf(%s, name);
printf(tel--- );
scanf(%s, tel);
} list *create_node() {
char *malloc();
return((list *)malloc(sizeof(list)));
} char *strsv(char *sl) { //입력받은 데이터크기+1만큼의 공간을 확보하여 데이터를 복사
char *p, *malloc();
if((p=malloc(strlen(sl)+1)) != null) //eol을 위한 공간 확보
strcpy(p, sl);
return(p);
} void prnt(list *pp, int lev) {
if(pp != null) { //중위 순회 알고리즘을 활용한 출력
prnt(pp-left, lev+1);
printf(%2d %-14s %15s \n, lev, pp-name, pp-tel);
prnt(pp-right, lev+1);
}
} list *srch(list *sp, char *snam) {
int cmp; if(sp != null) {
if((cmp=strcmp(snam, sp-name))==0) {
printf(\n name tel \n);
printf(-----------------------\n);
printf(%-14s %-15s \n, sp-name, sp-tel);
}
else if(cmp 0)
sp-left=srch(sp-left, snam);
else
sp-right=srch(sp-right, snam);
}
else
printf(search fail: %s is not exist in the tree \n, snam);
return(sp);
} list *modi(list *mp, char *mnam) {
char mtel[15];
int cmp; if(mp != null) {
if((cmp=strcmp(mnam, mp-name))==0) {
printf(tel-- );
scanf(%s, mtel);
strcpy(mp-name, mnam);
strcpy(mp-tel, mtel);
}
else if(cmp 0)
mp-left=modi(mp-left, mnam);
else
mp-right=modi(mp-right, mnam);
}
else
printf(search fail: %s is not exist in the tree \n, mnam);
return(mp);
} list *delet(list *dp, char *dnam) {
list *findmin(), *temp;
void free();
int cmp; if(dp==null)
printf(search fail no search name exist \n);
else if((cmp=strcmp(dnam, dp-name)) 0)
dp-left=delet(dp-left, dnam);
else if(cmp 0)
dp-right=delet(dp-right, dnam);
else if(dp-left && dp-right) { //두개의 자식이 있는 노드
temp=findmin(dp-right); //삭제될 노드를 검색
strcpy(dp-name, temp-&g temp-name); //데이터의 복사
strcpy(dp-tel, temp-tel);
dp-right=delet(dp-right, dp-name); //최소노드를 결정한다.
}
else { //하나의 자식이 있는 경우
temp=dp;
if(dp-left==null)
dp=dp-right;
else if(dp-right==null)
dp=dp-left;
free(temp);
}
return(dp);
} list *findmin(list *node) {
list *temp, *save; save=node;
temp=save-left; //오른쪽 부트리의 최소걋?최소값을 찾는다. while(temp != null) {
save=temp;
temp=temp-left;
}
return(save);
}

신청하기





COMMENT

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

번호 제 목 글쓴이 날짜
2700368 if에 관해서 질문이요... Orange 2025-07-04
2700339 이거 결과값이 왜이런건지.. (4) 그댸와나 2025-07-04
2700313 파일 읽어서 저장하는데 빈파일일 경우 문재가 발생하네요.. (2) 크나 2025-07-03
2700287 구조체 동적할당 연습을 하는데 오류가 뜹니다...(해결) (3) 아련나래 2025-07-03
2700264 문자와 숫자 동시에 입력??? 글고운 2025-07-03
2700236 txt파일로만 쓰고 읽게 하려면 어떻게 해야 하나요..?? (8) 미국녀 2025-07-03
2700211 전위 연산자 (2) 어른처럼 2025-07-02
2700183 C에서 파일이름을 받고, 그 파일의 사이즈를 출력해줘야하는데 내용이 출력이 안되네요 ;ㅅ; 피스케스 2025-07-02
2700150 꼭좀 도와주세요ㅠㅠㅠ 호습다 2025-07-02
2700095 연산문제...질문... 오빤테앵겨 2025-07-01
2700070 while문 , 3의배수 출력하는 프로그램좀 짜주세욤. 횃불 2025-07-01
2700041 초보인데요 ㅎ 배열안에 배열을 집어넣을수 있나요?? 헛장사 2025-07-01
2700012 배열// (1) 전갈자리 2025-07-01
2699895 무한루프에 빠집니다.!! 해결좀부탁드려요 (10) 선아 2025-06-30
2699842 질문을 너무 많이 하네여.....죄송.... (2) 해님꽃 2025-06-29
2699816 오류 질문입니다.. (1) 해비치 2025-06-29
2699763 질문입니다 ! 꼭 좀 도와주세요ㅠㅠ (2) 미라 2025-06-28
2699555 c언어 다항식을 입력을 했는데 왜 출력이 안될까요? 피스케스 2025-06-27
2699528 C언어 포인터연산 질문입니다. (3) 안녕나야 2025-06-26
2699476 끌어올림;;달력 짜봤는데요 이 소스 줄일 수 있나요? - 스샷첨부 (2) 클라우드 2025-06-26
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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