数据结构课程设计题目四_二叉树

本文出自:http://blog.csdn.net/svitter

题目4:二叉树

给出一颗无线的二叉树。树的每一个结点用一整数对标识。二叉树构造如下
树根被标识为(1, 1);

如果一个结点被标识为(a, b), 则其左孩子被标识为(a+b,b),右孩子被标识为(a, a+b)。现在给出某一结点(a, b),求树根到该结点的最短路径,并且同时求出从树根出发向左走和向右走的次数。建议完成人数1人。

注:此处使用了STL_stack库函数,是不允许的,我图方便。


//============================================================================
// Name        : BinaryTree.cpp
// Author      : Vit
// Version     : 1.0
// Copyright   : Your copyright notice
// Description : Hello World in C++, Ansi-style
//============================================================================

#include <iostream>
#include <stdio.h>
#include <stack>
using namespace std;

struct path
{
	int a;
	int b;
	path(int c, int d):a(c), b(d){}
	void print()
	{
		printf(" (%d, %d)", a, b);
	}
};

int main()
{
	int left, right;
	int a, b;
	stack <path> s;
	while(~scanf("%d%d", &a, &b ))
	{
		if(a == b && a != 1)
		{
			printf("impossible\n");
			continue;
		}
		right = left = 0;
		while(a != b)
		{
			if(a > b)
			{
				left++;
				s.push(path(a,b));
				a = a - b;
			}
			else
			{
				right++;
				s.push(path(a,b));
				b = b - a;
			}
		}
		printf("left_num: %d\nright_num:%d\n", left ,right);
		printf("(1,1)");
		while(!s.empty())
		{
			path b = s.top();
			s.pop();
			b.print();
		}
		printf("\n\n");
	}
	return 0;
}


树状显示二叉树: 编写函数displaytree(二叉树的根指针,数据值宽度,屏幕的宽度)输出树的直观示意图。输出的二叉树是垂直打印的,同层的节点在同一行上。 [问题描述] 假设数据宽度datawidth=2,而屏幕宽度screenwidth为64=26,假设节点的输出位置用 (层号,须打印的空格数)来界定。 第0层:根在(0,32)处输出; 第1层:因为根节点缩进了32个空格,所以下一层的偏移量(offset)为32/2=16=screenwidth/22。即第一层的两个节点的位置为(1,32-offset),(1,32+offset)即(1,16),(1,48)。 第二层:第二层的偏移量offset为screenwidth/23。第二层的个节点的位置 分别是(2,16-offset),(2,16+offset),(2,48-offset),(2,48+offset)即(2,8),(2,24),(2,40),(2,56)。 …… 第i层:第i层的偏移量offset为screenwidth/2i+1。第i层的每个节点的位置是访问第i-1层其双亲节点时确定的。假设其双亲的位置为(i-1,parentpos)。若其第i层的节点是其左孩子,那末左孩子的位置是(i,parentpos-offset),右孩子的位置是(i,parentpos+offset)。 [实现提示] 利用二叉树的层次遍历算法实现。利用两个队列Q,QI。队列Q中存放节点信息,队列QI中存相应于队列Q中的节点的位置信息,包括层号和需要打印节点值时需要打印的空格数。当节点被加入到Q时,相应的打印信息被存到QI中。二叉树本身采用二叉链表存储。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值