亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? program.cs

?? 高度平衡二叉樹
?? CS
?? 第 1 頁 / 共 2 頁
字號:
?using System;
using System.Collections.Generic;
using System.Text;

namespace HeightBalancedTree
{
    class Node
    {
        public int data;
        public Node lchild;
        public Node rchild;
        public int BF;
        public Node preNode;
    }
    class BalancedTree
    {
        Node root = new Node();
        int[] array = new int[10];
        static int index = 0;

        public BalancedTree()
        {
            root = null;
        }
        public void insert()
        {
            Node parent = null;
            Node current = null;
            Node newNode = new Node();
            Console.Write("Input the data:");
            newNode.data = Convert.ToInt32(Console.ReadLine());
            newNode.BF = 0;
            if (root == null)
            {
                root = newNode;
                root.preNode = null;
            }
            else
            {
                find(newNode.data, ref parent, ref current);
                if (current != null)
                {
                    Console.WriteLine("Duplicates are not allowed!");
                    return;
                }
                else
                {
                    if (newNode.data < parent.data)
                    {
                        parent.lchild = newNode;
                    }
                    else
                    {
                        parent.rchild = newNode;
                    }
                    newNode.preNode = parent;
                    Node ptr = parent;
                    int i = index - 1;
                    while (ptr != null)
                    {
                        ptr.BF += array[i--];
                        if (ptr.BF == 0)
                        {
                            Console.WriteLine("It is a balanced tree !");
                            return;
                        }
                        else if ((ptr.BF != 0) && (ptr.BF != 1) && (ptr.BF != -1))
                        {
                            Console.WriteLine("Not balanced !");
                            balance(ptr, newNode);
                            return;
                        }
                        ptr = ptr.preNode;
                    }
                    Console.WriteLine("It is a balanced tree!");
                }
            }
        }
        public void balance(Node keyNode, Node newNode)
        {
            Console.WriteLine("Balance the tree...\n");
            Console.WriteLine("Before:");
            traverse();
            Node ptrParent = new Node();
            ptrParent = keyNode.preNode;

            if (keyNode.BF == 2)
            {
                if (keyNode.lchild.BF == 1) //LL
                {
                    Node tempNode = keyNode.lchild;
                    keyNode.lchild = tempNode.rchild;
                    tempNode.rchild = keyNode;
                    tempNode.rchild.preNode = keyNode;
                    keyNode.preNode = tempNode;

                    if (keyNode == root)
                    {
                        tempNode.preNode = null;
                        root = tempNode;
                        root.BF = 0;
                        root.rchild.BF = 0;
                    }
                    else
                    {
                        tempNode.preNode = ptrParent;
                        keyNode = tempNode;
                        keyNode.BF = 0;
                        keyNode.rchild.BF = 0;
                    }
                }
                else
                {
                    if (keyNode.lchild.rchild.BF == 0) //LR
                    {
                        newNode.lchild = keyNode.lchild;
                        newNode.rchild = keyNode;
                        keyNode.lchild.preNode = newNode;
                        keyNode.preNode = newNode;
                        if (root == keyNode)
                        {
                            newNode.preNode = null;
                            root = newNode;
                            root.lchild.rchild = null;
                            root.rchild.lchild = null;
                            root.lchild.BF = 0;
                            root.rchild.BF = 0;
                        }
                        else
                        {
                            newNode.preNode = ptrParent;
                            keyNode = newNode;
                            keyNode.lchild.rchild = null;
                            keyNode.rchild.lchild = null;
                            keyNode.lchild.BF = 0;
                            keyNode.rchild.BF = 0;
                        }
                    }
                    else if (keyNode.lchild.rchild.BF == 1) //LR(L)
                    {
                        Node tempNode = newNode.preNode;
                        ptrParent.lchild = tempNode;
                        tempNode.rchild = keyNode;
                        keyNode.preNode = tempNode;
                        keyNode.lchild.rchild = tempNode.lchild;
                        tempNode.lchild.preNode = keyNode.lchild;
                        tempNode.lchild = keyNode.lchild;
                        keyNode.lchild.preNode = tempNode;

                        if (keyNode == root)
                        {
                            tempNode.preNode = null;
                            root = tempNode;
                            keyNode.BF = 0;
                            root.lchild.BF = 0;
                            root.rchild.BF = -1;
                        }
                        else
                        {
                            tempNode.preNode = ptrParent;
                            tempNode.BF = 0;
                            tempNode.lchild.BF = 0;
                            tempNode.rchild.BF = -1;
                        }
                        tempNode.rchild.lchild = null;
                    }
                    else //LR(R)
                    {
                        Node tempNode = newNode.preNode;
                        tempNode.lchild = keyNode.lchild;
                        keyNode.lchild = tempNode.rchild;
                        tempNode.rchild = keyNode;
                        keyNode.lchild.preNode = tempNode;
                        tempNode.rchild.preNode = keyNode;
                        keyNode.preNode = tempNode;
                        if (keyNode == root)
                        {
                            tempNode.preNode = null;
                            root = tempNode;
                            root.BF = 0;
                            root.lchild.BF = 1;
                            root.rchild.BF = 0;
                        }
                        else
                        {
                            tempNode.preNode = ptrParent;
                            keyNode = tempNode;
                            keyNode.BF = 0;
                            keyNode.lchild.BF = 1;
                            keyNode.rchild.BF = 0;
                        }
                        keyNode.lchild.rchild = null;
                    }
                }
            }
            else if (keyNode.BF == -2)
            {
                if (keyNode.rchild.BF == -1) //RR
                {
                    Node tempNode = keyNode.rchild;
                    keyNode.rchild = tempNode.lchild;
                    tempNode.lchild.preNode = keyNode;
                    tempNode.lchild = keyNode;
                    keyNode.preNode = tempNode;
                    if (keyNode == root)
                    {
                        tempNode.preNode = null;
                        root = tempNode;
                        root.BF = 0;
                        root.lchild.BF = 0;
                    }
                    else
                    {
                        tempNode.preNode = ptrParent;
                        tempNode.BF = 0;
                        tempNode.lchild.BF = 0;
                    }
                }
                else
                {
                    if (keyNode.rchild.lchild.BF == 0) //RL
                    {
                        newNode.lchild = keyNode;
                        newNode.rchild = keyNode.rchild;
                        //keyNode.preNode.rchild = newNode;

                        keyNode.preNode = newNode;
                        keyNode.rchild.preNode = newNode;
                        if (keyNode == root)
                        {
                            newNode.preNode = null;
                            root = newNode;
                            root.lchild.rchild = null;
                            root.rchild.lchild = null;
                            root.lchild.BF = 0;
                            root.rchild.BF = 0;
                        }
                        else
                        {
                            ptrParent.rchild = newNode;
                            newNode.preNode = ptrParent;
                            //keyNode = newNode;
                            newNode.lchild.rchild = null;
                            newNode.rchild.lchild = null;
                            newNode.lchild.BF = 0;
                            newNode.rchild.BF = 0;
                        }
                    }
                    else if (keyNode.rchild.lchild.BF == 1) //RL(L)
                    {
                        Node tempNode = newNode.preNode;
                        tempNode.rchild = keyNode.rchild;
                        keyNode.rchild = tempNode.lchild;
                        tempNode.lchild = keyNode;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲激情av在线| 青青草成人在线观看| 天天综合网天天综合色| 国产盗摄一区二区三区| 欧美日韩国产大片| 亚洲丝袜美腿综合| 麻豆国产91在线播放| 91久久国产综合久久| 国产色一区二区| 美女精品一区二区| 69久久99精品久久久久婷婷| 精品免费视频一区二区| 亚洲国产裸拍裸体视频在线观看乱了 | 日韩成人午夜精品| 一本高清dvd不卡在线观看| 久久一区二区三区四区| 三级成人在线视频| 在线观看视频91| ...av二区三区久久精品| 国产999精品久久| 精品成人在线观看| 精品一区二区三区欧美| 日韩一级免费观看| 日韩av一级片| 日韩一级免费观看| 日本欧美一区二区| 欧美一区二区二区| 蜜臀av亚洲一区中文字幕| 欧美嫩在线观看| 奇米色一区二区| 欧美电视剧在线看免费| 久久精品国产一区二区| 日韩欧美综合一区| 麻豆精品视频在线观看| 日韩一区二区三| 国产伦精一区二区三区| 日本一区二区三区视频视频| 国产99久久久国产精品潘金网站| 久久综合久久综合九色| 国产福利精品导航| 中文字幕视频一区二区三区久| 成人综合婷婷国产精品久久免费| 国产精品美女久久久久高潮| 99riav一区二区三区| 一区二区三区色| 7777精品伊人久久久大香线蕉| 日本中文在线一区| 国产欧美日韩不卡免费| 成人av电影在线观看| 亚洲一区自拍偷拍| 日韩女优毛片在线| 成人免费视频视频在线观看免费| 综合激情成人伊人| 欧美老肥妇做.爰bbww视频| 美女脱光内衣内裤视频久久网站 | 99国产精品国产精品久久| 一区二区三区成人| 国产午夜亚洲精品理论片色戒| 成人午夜碰碰视频| 亚洲一区二区三区在线播放| 精品欧美黑人一区二区三区| 99免费精品在线观看| 亚洲.国产.中文慕字在线| 日韩精品自拍偷拍| 91伊人久久大香线蕉| 日韩国产成人精品| 国产精品对白交换视频| 欧美一区二区久久| 不卡视频在线看| 欧美96一区二区免费视频| 国产精品毛片久久久久久| 91精品在线观看入口| gogo大胆日本视频一区| 日韩高清不卡一区| 中文字幕日韩欧美一区二区三区| 欧美日韩一区二区三区四区五区| 国产精品资源在线| 亚洲第一电影网| 亚洲国产精品av| 欧美一级夜夜爽| 91福利社在线观看| 国产99久久精品| 久久99精品国产麻豆不卡| 一区二区在线免费| 日韩一区在线播放| 久久影院电视剧免费观看| 欧美日韩久久久一区| 91免费在线视频观看| 精品中文字幕一区二区| 亚洲一区二区视频在线| 国产精品久久免费看| 欧美成人午夜电影| 69堂成人精品免费视频| 欧美三区在线观看| 色综合久久综合| 91在线视频播放地址| 国产成人午夜片在线观看高清观看| 奇米精品一区二区三区在线观看 | 色哟哟日韩精品| 高清视频一区二区| 国产精品系列在线播放| 蜜桃一区二区三区在线观看| 亚洲超丰满肉感bbw| 亚洲欧美日韩综合aⅴ视频| 国产欧美一区二区精品秋霞影院| 欧美xxxxxxxx| 精品国产一区久久| 久久亚洲捆绑美女| 久久一区二区三区国产精品| 日韩一区二区三区观看| 日韩免费福利电影在线观看| 9191久久久久久久久久久| 欧美男人的天堂一二区| 欧美一区二区三区在| 91精品国产高清一区二区三区蜜臀| 欧美日韩一区成人| 欧美喷水一区二区| 日韩女优毛片在线| 久久久久国色av免费看影院| 亚洲国产电影在线观看| 国产精品国产三级国产三级人妇 | 看片的网站亚洲| 麻豆国产欧美一区二区三区| 精品影院一区二区久久久| 久久99国产精品久久| 国产精品88888| 不卡av电影在线播放| 91丨porny丨最新| 欧美日韩在线观看一区二区 | 欧美午夜不卡在线观看免费| 欧洲人成人精品| 91精品国产综合久久久久久漫画 | 99r精品视频| 欧美日韩一区中文字幕| 91精品欧美综合在线观看最新| 欧美v亚洲v综合ⅴ国产v| 国产肉丝袜一区二区| 亚洲人成亚洲人成在线观看图片 | 成人av资源站| 欧美日韩在线免费视频| 日韩欧美国产一二三区| 国产精品青草久久| 亚洲123区在线观看| 国产激情91久久精品导航| 一本一道久久a久久精品综合蜜臀| 欧美日韩卡一卡二| 国产欧美一区视频| 午夜精品国产更新| 国产成人精品亚洲日本在线桃色| 色嗨嗨av一区二区三区| 精品乱码亚洲一区二区不卡| **欧美大码日韩| 久久成人18免费观看| 91捆绑美女网站| 日韩免费成人网| 亚洲欧洲在线观看av| 蜜桃一区二区三区在线观看| av电影天堂一区二区在线观看| 日韩一区二区在线看| 亚洲人成精品久久久久| 国产精品自拍网站| 337p亚洲精品色噜噜噜| 日韩美女久久久| 国产精品综合网| 日韩一级二级三级| 亚洲伊人伊色伊影伊综合网| 国产一区二区视频在线| 欧美日韩在线播放三区四区| 国产精品成人在线观看| 精品在线观看免费| 在线播放亚洲一区| 亚洲精品中文字幕在线观看| 国产一区二区免费在线| 9191国产精品| 亚洲成av人影院在线观看网| aaa欧美色吧激情视频| 精品av综合导航| 日本亚洲欧美天堂免费| 欧美人妇做爰xxxⅹ性高电影| 国产精品毛片大码女人| 国产大片一区二区| 久久色.com| 久久er精品视频| 日韩一卡二卡三卡国产欧美| 亚洲综合成人在线| 91免费观看在线| 综合久久久久久| 成人免费av网站| 国产视频911| 风间由美一区二区av101| 久久久亚洲精华液精华液精华液| 奇米888四色在线精品| 制服.丝袜.亚洲.另类.中文| 亚洲成av人片观看| 欧美主播一区二区三区| 亚洲国产综合色| 欧美日韩国产高清一区二区 | 欧美精品在线一区二区| 水野朝阳av一区二区三区| 欧美久久久久久久久中文字幕|