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.

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

codeforces 786B (线段树构图+最短路径)

线段树构图,跑最短路

数据结构 二叉树路径问题

  • 2013年09月08日 21:04
  • 152KB
  • 下载

HHU暑期第五弹——图论入门(图的搜索+连通性+最短路径+生成树+二分图匹配+最大流)

第五弹图论入门的主要内容有以下几部分:图的搜索、连通性、最短路径、生成树、二分图匹配、最大流等内容。 一、图的搜索 二、连通性 三、最短路径 四、生成树 五、二分图匹配 六、最大流...

求二叉树从根节点到每个叶子节点路径上不重复数字的最大个数

问题这个题我在做一个测试的时候做的,当时我忘记保存题目了,只是记着题目大意:求二叉树从根节点到每个叶子节点路径上不重复数字的最大个数。举个例子,如下二叉树:从根节点到叶子节点的路径总过有三条:(1,3...

获取树项的路径

  • 2013年12月23日 22:41
  • 32KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:26886: 树的路径
举报原因:
原因补充:

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