전위 트리 만들기
글쓴이: qubick / 작성시간: 토, 2007/11/17 - 11:45오후
전위식으로 표기된 다항식을 입력받아 트리를 구성하는 함수입니다.
입력은 +-ABC= 식으로 받을거구요.
제가 보기엔 전~혀(?) 문제가 없어보이는데,
프로그램을 실행시키면 안에서 무한루프가 도는 거 같아요.
return 하면서 제 부모 노드를 못 찾아가는 걸까요?
처음 입력 당시에는 인자를 루트로 넘겨줍니다. ( treeNode *getRoot());
뭐가 문제인지 좀 봐 주세요.
클래스 구조와 해당 함수 구현부입니다.
class treeNode
{
friend class Tree;
private:
treeNode *Lchild;
treeNode *Rchild;
char data;
};
class Tree
{
public:
Tree(); //생성자
void makeTree(treeNode *temp);
void printTree(treeNode *temp);
int calTreeValue(treeNode *root);
treeNode* getRoot();
private:
treeNode* root;
char variable[MAX_NUM]; //다항식의 피연산자 변수를 저장할 배열
int num[MAX_NUM]; //피연산자 변수에 실제로 저장될 숫자
};void Tree::makeTree(treeNode *temp){
treeNode *pNode = NULL;
char input;
cin >> input;
while(input != '='){
if(input == '+'||'-'||'*'||'/'){ //입력이 연산자이면
temp->data = input;
pNode = new treeNode;
temp->Lchild = pNode;
makeTree(pNode); //이를 루트로 하여 서브트리 생성
}
else if(input >= 'A' && input <= 'Z'){
temp->data = input;
temp->Lchild = NULL; //변수는 리프노드이므로 자식노드 없음
temp->Rchild = NULL;
return;
}
if(temp->Rchild == NULL){ //왼쪽 서브트리의 입력을 끝내고 오른쪽 서브트리 입력
pNode = new treeNode;
temp->Rchild = pNode;
makeTree(pNode);
} else {
return;
}
}
}Forums:


makeTree 의 시작부분과
makeTree 의 시작부분과 끝 그리고 input 을 받는 부분에서 디버깅용 출력을 넣어서 한번 따라가보세요.
--
오랫동안 꿈을 그리는 사람은 그 꿈을 닮아간다...
http://mytears.org ~(~_~)~
나 한줄기 바람처럼..
오랫동안 꿈을 그리는 사람은 그 꿈을 닮아간다...
http://mytears.org ~(~_~)~
나 한줄기 바람처럼..
댓글 달기