通过有序数组生成平衡搜索二叉树
2017-11-27 10:43
453 查看
//通过有序数组生成平衡搜索二叉树
public class generateBST{
//二叉树节点的定义
public static class Node{
public int value;
public Node left;
public Node right;
public Node(int data)
{
this.value=data;
}
}
//生成平衡二叉搜索树
public static Node generateBSTree(int[]arr)
{
if(arr==null)
{
return null;
}
return generate(arr,0,arr.length-1);
}
//递归生成二叉排序树
public static Node generate(int[]arr,int start,int end)
{
if(start>end)
{
return null;
}
int mid=(start+end)/2;
Node head=new Node(arr[mid]);//生成头节点
head.left=generate(arr,start,mid-1);
head.right=generate(arr,mid+1,end);
return head;
}
//***************************************************
//直观打印二叉树
public static void printTree(Node head) {
System.out.println("Binary Tree:");
printInOrder(head, 0, "H", 17);
System.out.println();
}
public static void printInOrder(Node head, int height, String to, int len) {
if (head == null) {
return;
}
printInOrder(head.right, height + 1, "v", len);
String val = to + head.value + to;
int lenM = val.length();
int lenL = (len - lenM) / 2;
int lenR = len - lenM - lenL;
val = getSpace(lenL) + val + getSpace(lenR);
System.out.println(getSpace(height * len) + val);
printInOrder(head.left, height + 1, "^", len);
}
public static String getSpace(int num) {
String space = " ";
StringBuffer buf = new StringBuffer("");
for (int i = 0; i < num; i++) {
buf.append(space);
}
return buf.toString();
}
//************************************************
public static void main(String[]args)
{
int[]arr={1,2,3,4};
Node head=generateBSTree(arr);
printTree(head);
}
}
相关文章推荐
- 二叉树问题---通过有序数组生成平衡搜索二叉树
- 二叉树问题---通过先序和中序数组生成后序数组
- 【LeetCode101-110】二叉树对称及存储,前序中序遍历生成二叉树,中序后序生成二叉树,数组转化为AVL平衡树,判断二叉树是否平衡
- 有序单向链表转换为平衡搜索二叉树
- 【IT笔试面试题整理】有序数组生成最小高度二叉树
- 通过先序、中序和后序数组两两结合重构二叉树
- 通过先序和中序数组生成后序数组
- java通过数组描述二叉树
- 108. Convert Sorted Array to Binary Search Tree 109. Convert Sorted List to Binary Search Tree -- 将有序数组或有序链表转成平衡二叉排序树
- 有序数组创建一棵平衡的BST
- 如何将一个有序数组快速插入到一个二叉树中
- 二分搜索典型应用(一)从有序数组中查找某个值
- leetcode之数组类之数组的旋转与分治类-----OJ 189/33/81/153/154 数组旋转 旋转数组搜索 88 有序数组合并 4 两个有序数组寻找第K个元素/中位数 35 寻找插入位置
- 堆栈和通过一个数组还原二叉树
- AVL平衡搜索二叉树
- 根据后序数组重建搜索二叉树
- 怎样编写一个程序,把一个有序整数数组放到二叉树中?
- 平衡有序二叉树(AVL Tree)的C++实现
- 题目:把一个有序整数数组放到二叉树。
- 把一个有序整数数组放到二叉树中