26886: 树的路径

原创 2015年07月10日 09:46:08
题目描述
给定一棵二叉树和两个不同的节点,求出他们到最近的公共祖先父节点的路径。已知该二叉树有n个节点,标号1..n。(n<100)
输入
输入:
第一行两个整数x,y,表示需要求的节点;
以下若干行,每行两个整数a和b,表示a的父节点是b。
输出
X到y的路径。
样例输入
9 7
2 1
3 2
4 2
5 3
8 5
9 5
6 4
7 4

样例输出
9 5 3 2 4 7 

program x26886;
const maxn=100;
var father,a,b:array[1..maxn] of integer;
x,y,root:integer;

procedure init;
var a,b:integer;
begin
 readln(x,y);
 while not eof do
 begin
  readln(a,b);
  father[a]:=b;
 end;
end;

procedure findroot;
var i,j:integer;
begin
 i:=x;
 while i<>0 do
 begin
  a[i]:=1;
  i:=father[i];
 end;
 j:=y;
 while a[j]<>1 do
 j:=father[j];
 root:=j;
end;

procedure finda(i:integer);
begin
 if i<>root then
 begin
  write(i,' ');
  finda(father[i]);
 end;
end;

procedure findb(i:integer);
begin
 if i<>root then
 begin
  findb(father[i]);
  write(i,' ');
 end;
end;

begin
 init;
 findroot;
 finda(x);
 write(root,' ');
 findb(y);
end.

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

树8 堆中的路径 (25分)

将一系列给定数字插入一个初始为空的小顶堆H[]。随后对任意给定的下标i,打印从H[i]到根结点的路径。  输入格式: 每组测试第1行包含2个正整数NNN和MMM(≤1000\le 1000≤1...

CodeForces 827D Round #423 Div2F&Div1D:LCA+路径压缩+MST(最小生成树)

题意:给出一张n( 题解:既然是生成树相关问题,那么我们先考虑图中任意一个MST,按照kruskal算法,MST可以这样得到:按边权排序,加入m-1条端点不在一个并查集的边。这样一来的话,所有的m条边...

二叉树中节点的最大距离(树的最长路径)——递归解法

问题描述: 如果我们把二叉树看成一个图,父子节点之间的连线看成是双向的, 我们姑且定义"距离"为两节点之间边的个数。 写一个程序, 求一棵二叉树中相距最远的两个节点之间的距离。
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)