전위 트리 만들기
글쓴이: 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 ~(~_~)~
나 한줄기 바람처럼..
댓글 달기