亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
欧美电视剧免费全集观看| 亚洲欧美日韩中文播放| 欧美激情在线一区二区| 午夜日韩在线观看| 不卡一区二区中文字幕| 2019国产精品| 婷婷成人激情在线网| 色婷婷亚洲精品| 日本一区二区电影| 激情欧美一区二区| 日韩一区二区三区免费看 | av一区二区不卡| 欧美一区二区三区系列电影| 亚洲精品久久久蜜桃| 国产成人精品午夜视频免费| 日韩美女在线视频| 日韩中文字幕一区二区三区| 色婷婷激情综合| 1000精品久久久久久久久| 国产美女一区二区| 久久亚洲一区二区三区四区| 日韩av网站在线观看| 欧美精品亚洲二区| 无码av免费一区二区三区试看 | 777亚洲妇女| 亚洲国产视频在线| 欧美性猛交一区二区三区精品| 亚洲精品写真福利| 91福利在线免费观看| 亚洲综合图片区| 色婷婷av一区二区三区gif | 免费在线观看成人| 日韩一卡二卡三卡国产欧美| 日本欧美在线观看| 日韩欧美成人激情| 国产成人在线看| 国产精品乱码妇女bbbb| 成人福利电影精品一区二区在线观看| 久久久久久电影| 成人免费视频视频| 亚洲精品成人少妇| 欧美疯狂做受xxxx富婆| 美女性感视频久久| 国产日产欧美精品一区二区三区| 国产精品1024久久| 亚洲欧美一区二区久久| 在线观看视频一区二区| 日韩精品视频网| 久久久久久亚洲综合| 不卡av在线免费观看| 亚洲影院在线观看| 精品久久一二三区| 91视频在线观看| 亚洲成人免费av| 日韩午夜小视频| 成人免费视频app| 亚洲午夜精品久久久久久久久| 欧美一级欧美三级在线观看| 国内成人精品2018免费看| 国产精品福利一区| 欧美日韩高清不卡| 国产乱码精品一区二区三| 亚洲人妖av一区二区| 在线成人av网站| 成人a级免费电影| 欧美aaaaa成人免费观看视频| 久久精品视频一区| 欧美日韩中文字幕精品| 国产在线观看一区二区| 亚洲综合偷拍欧美一区色| 精品国产污网站| 在线看一区二区| 国产乱子轮精品视频| 亚洲国产精品一区二区尤物区| 26uuu色噜噜精品一区| 一本久久a久久精品亚洲| 国产真实精品久久二三区| 一区二区国产盗摄色噜噜| 国产日韩欧美综合在线| 欧美男女性生活在线直播观看| 成人亚洲一区二区一| 久久精品国产一区二区三区免费看| 亚洲欧美综合网| 日韩欧美不卡在线观看视频| 欧美亚洲愉拍一区二区| 成人激情动漫在线观看| 激情伊人五月天久久综合| 亚洲亚洲人成综合网络| 亚洲婷婷在线视频| 国产日韩欧美综合一区| 欧美电影免费观看高清完整版在| 一本色道久久综合亚洲精品按摩| 国产精品一区二区果冻传媒| 男男视频亚洲欧美| 亚洲国产婷婷综合在线精品| 亚洲日本青草视频在线怡红院| 国产亚洲综合av| 久久久久亚洲综合| 欧美v日韩v国产v| 日韩视频在线观看一区二区| 欧美精三区欧美精三区| 91高清在线观看| 欧美午夜不卡视频| 欧美在线观看一二区| 欧美中文一区二区三区| 色综合天天综合狠狠| 国产精品一区二区三区四区| 天天色天天操综合| 亚洲1区2区3区4区| 亚洲国产aⅴ天堂久久| 一区二区三区美女| 亚洲自拍偷拍图区| 亚洲自拍偷拍av| 亚洲无线码一区二区三区| 亚洲另类春色校园小说| 亚洲三级电影全部在线观看高清| 国产精品久久夜| 国产精品久久久久久亚洲伦 | 国产精品亚洲视频| 国产精一区二区三区| 激情五月播播久久久精品| 国产一区二区在线电影| 国产乱码精品一区二区三区av | www久久久久| 久久精品视频免费| 中文字幕在线播放不卡一区| 亚洲精品视频在线看| 亚洲大片一区二区三区| 日韩中文字幕亚洲一区二区va在线| 首页欧美精品中文字幕| 精品中文字幕一区二区| 国产成人高清视频| 色婷婷av一区二区三区大白胸| 欧美日韩国产中文| 2020国产精品| 亚洲欧美日韩国产另类专区| 五月婷婷欧美视频| 国内外成人在线| 99久久精品情趣| 欧美精品乱码久久久久久按摩| 精品处破学生在线二十三| 国产精品高潮呻吟| 日本va欧美va精品| zzijzzij亚洲日本少妇熟睡| 日本韩国欧美在线| 久久久不卡网国产精品二区| 国产精品国产三级国产| 日韩av中文字幕一区二区 | 免费的成人av| 成人毛片视频在线观看| 欧美性xxxxx极品少妇| 精品国产伦一区二区三区观看方式 | 99热在这里有精品免费| 欧美体内she精视频| 在线一区二区视频| 久久精品人人做| 亚洲成人激情av| 成人av第一页| 日韩欧美国产1| 亚洲一区二区五区| 国产不卡高清在线观看视频| 欧美日本韩国一区二区三区视频| 国产欧美一区二区精品性色超碰 | 国产校园另类小说区| 亚洲一区二区精品视频| 粗大黑人巨茎大战欧美成人| 7777精品伊人久久久大香线蕉最新版| 久久精品在线观看| 蜜臀av一区二区三区| 欧美午夜精品一区二区蜜桃| 亚洲国产成人自拍| 久久99久国产精品黄毛片色诱| 91视频免费播放| 久久久久国产成人精品亚洲午夜| 五月天视频一区| 欧美专区日韩专区| 亚洲三级在线播放| 不卡一区在线观看| 国产农村妇女精品| 狠狠狠色丁香婷婷综合久久五月| 欧美日韩高清一区| 亚洲地区一二三色| 欧美色图片你懂的| 亚洲永久免费视频| 在线中文字幕一区| 一区二区三区不卡视频在线观看| a在线欧美一区| 国产日韩欧美在线一区| 成人午夜av在线| 精品成a人在线观看| 久久99久久久欧美国产| 欧美成人乱码一区二区三区| 亚洲高清免费观看| 欧美性猛片aaaaaaa做受| 亚洲综合在线免费观看| 色视频欧美一区二区三区| 亚洲精品成人在线| 欧亚洲嫩模精品一区三区| 亚洲激情图片小说视频| 91极品视觉盛宴|