文章
1
粉丝
58
获赞
0
访问
6.2k
#include <iostream>
#include <string>
using namespace std;
string s;
int go(int i) {
if (i < 0 || i >= s.size()) return -1;
if (s[i] == '#') return i + 1;
int next = go(i + 1);
cout << s[i] << ' ';
return go(next);
}
int main() {
while (getline(cin, s)) {
go(0);
cout << endl;
}
}
不建树,跑字符串就行
next代表了子树向母节点反映其下一个节点的坐标,go(i+1)那里是访问左子树后它向母节点返回了右子树的坐标,go(next)则是访问了右子树后它返回了母节点邻居的坐标
字符串表示法
前序[母,左子树,右子树]
中序[左子树,母,右子树]
后序[左子树,右子树,母]
登录后发布评论
暂无评论,来抢沙发