二叉树怎么用非递归的方法打印出到某一节点的路径呢

yuhaouestc 2017-05-22 05:41:04
bool GetNodePath(vector<TreeNode*> &v, TreeNode* root, TreeNode* node)
{
bool find = false;
stack<TreeNode*> st;
st.push(root);
while (!st.empty())
{
TreeNode* temp = st.top();
st.pop();
v.push_back(temp);
if (temp == node)
{
find = true;
break;
}
else
{
if (temp->right)
st.push(temp->right);
if (temp->left)
st.push(temp->left);
}
}
return find;
}

就是想只保存到某一节点的路径,这样写得画会保存所有查找过的路径
只能用递归吗
...全文
228 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
paschen 版主 2017-05-23
  • 打赏
  • 举报
回复
能用递归的代码都有办法转换成非递归的形式,只是可能代码较多

64,282

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧