이진탐색트리 디스크 기반??
앤드류
질문 제목 : 질문 내용 :이진탐색트리를 디스크 기반으로 짜오라는데 먼말인지 잘 모르겟네여 ㅜㅜ
#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);
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |