python实现二叉树

        最近对python比较感兴趣,基本看完了网上流传甚广的 简明python教程,自己也试着玩了玩,感觉python确实是一门优雅的语言。

        前几天在网上看到一个python的二叉树代码,也学着写了写,增加了对二叉树的遍历方法。

        代码如下:

         不知道格式有没有乱


#!/usr/bin/python
#*_*coding:utf-8*_*

import os

class Node:
    
    def __init__(self, value = None, parent = None , left = None, right = None):
        self.value = value
        self.parent = parent
        self.left = left
        self.right = right

def wideOrder(n):
    if n==None:
        return
    l = list()
    l.append(n)
    while len(l)>0:
        tmp = l.pop(0)
        print tmp.value
        if tmp.left!=None:
            l.append(tmp.left)
        if tmp.right!=None:
            l.append(tmp.right)

def preOrder(n):
    if n==None:
        return
    print n.value
    preOrder(n.left)
    preOrder(n.right)

def midOrder(n):    
    if n==None:
        return
    midOrder(n.left)
    print n.value
    midOrder(n.right)

def aftOrder(n):
    if n==None:
        return
    aftOrder(n.left)
    aftOrder(n.right)
    print n.value

def getDepth(n):
    if n==None:
        return 0;
    n_left = getDepth(n.left)
    n_right = getDepth(n.right)

    if n_left>=n_right:
        return n_left+1
    else:
        return n_right+1

class Tree:

    def __init__(self):
        self.root = None
        self.size = 0
        self.depth = 0

    def insert(self, n):
        if n == None:
            return

        if self.root == None:
            self.root = n
            self.size=self.size+1
            self.depth = 1
            return

        tmp = self.root
        tmpDepth = 1
        while True:
            tmpDepth = tmpDepth+1
            if n.value <= tmp.value:
                if tmp.left == None:
                    n.parent = tmp
                    tmp.left = n
                    self.size = self.size+1
                    self.depth = max(self.depth, tmpDepth)
                    break
                else:
                    tmp = tmp.left
            elif n.value > tmp.value:
                if tmp.right == None:
                    n.parent = tmp
                    tmp.right = n
                    self.size = self.size+1
                    self.depth = max(self.depth, tmpDepth)
                    break
                else:
                    tmp=tmp.right

    def find(self, v):
        if v==None or self.root==None:
            print 'None'
            return
        tmp=self.root
        while True:
            if v==tmp.value:
                print 'find it ', v
                break
            elif v

python丰富的模块,和脚本的特性比较适合进行快速开发,对一些算法的演示也比较方便。

你可能感兴趣的:(Python)