면접 문제 06: 이원 트 리 에서 특정한 값 의 모든 경 로 를 찾 습 니 다 (미 완성 대기)
struct BinaryTreeNode // a node in the binary tree
{
int m_nValue; // value of node
BinaryTreeNode *m_pLeft; // left child of node
BinaryTreeNode *m_pRight; // right child of node
}
분석: 우선 생각 나 는 것 은 중 서 를 옮 겨 다 니 는 것 이다.
void FindPath(BinaryTreeNode* pTreeNode,int expectedSum,vector<BinaryTreeNode*> &path,int &sum){
if(root==NULL){
return;
}
BinaryTreeNode* pNode=root;
vector<BinaryTreeNode*> path;
int sum=0;
sum+=pNode->m_nValue;
path.push_back(pNode);
bool isLeaf=(pNode->m_pLeft==NULL && pNode->m_pRight==NULL);
if(isLeaf && sum==expectedSum){
for(int i=0;i<path.size();i++){
cout<<path[i]->m_nValue<<ends;
}
}else{
if(pNode->p_mLeft!=NULL){
FindPath(pNode->p_mLeft,expectedsum,path,sum);
}
if(pNode->p_mRight!=NULL){
FindPath(pNode->p_mRight,expectedsum,path,sum);
}
}
//return to its parent
sum-=pNode->m_nValue;
path.pop_back();
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.