资源简介

数据结构与算法分析:C语言描述_原书第2版_高清带书签DPF

资源截图

代码片段和文件信息

#include “aatree.h“
#include 
#include “fatal.h“

/* START: fig12_27.txt */
            /* Returned for failures */
        Position NullNode = NULL;  /* Needs more initialization */

        struct AANode
        {
            ElementType Element;
            AATree      Left;
            AATree      Right;
            int         Level;
        };

        AATree
        Initialize( void )
        {
            if( NullNode == NULL )
            {
                NullNode = malloc( sizeof( struct AANode ) );
                if( NullNode == NULL )
                    FatalError( “Out of space!!!“ );
                NullNode->Left = NullNode->Right = NullNode;
                NullNode->Level = 0;
            }
            return NullNode;
        }
/* END */

        AATree
        MakeEmpty( AATree T )
        {
            if( T != NullNode )
            {
                MakeEmpty( T->Left );
                MakeEmpty( T->Right );
                free( T );
            }
            return NullNode;
        }

        Position
        Find( ElementType X AATree T )
        {
            if( T == NullNode )
                return NullNode;
            if( X < T->Element )
                return Find( X T->Left );
            else
            if( X > T->Element )
                return Find( X T->Right );
            else
                return T;
        }

        Position
        FindMin( AATree T )
        {
            if( T == NullNode )
                return NullNode;
            else
            if( T->Left == NullNode )
                return T;
            else
                return FindMin( T->Left );
        }

        Position
        FindMax( AATree T )
        {
            if( T != NullNode )
                while( T->Right != NullNode )
                    T = T->Right;

            return T;
        }

        /* This function can be called only if K2 has a left child */
        /* Perform a rotate between a node (K2) and its left child */
        /* Update heights then return new root */

        static Position
        SingleRotateWithLeft( Position K2 )
        {
            Position K1;

            K1 = K2->Left;
            K2->Left = K1->Right;
            K1->Right = K2;

            return K1;  /* New root */
        }

        /* This function can be called only if K1 has a right child */
        /* Perform a rotate between a node (K1) and its right child */
        /* Update heights then return new root */

        static Position
        SingleRotateWithRight( Position K1 )
        {
            Position K2;

            K2 = K1->Right;
            K1->Right = K2->Left;
            K2->Left = K1;

            return K2;  /* New root */
        }

/* START: fig12_29.txt */
        /* If T‘s left child is on the same level as T */
        /* perform a rotation */

        AATree
        Skew( AATree T )
        {
            if( T->Left->Level == T->Level )
                T = SingleRotateWithLeft( T

 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----
     目录           0  2017-06-23 21:00  answers\
     文件        4112  2001-09-19 12:54  answers\ch00.pdf
     文件       11708  2001-09-19 12:54  answers\ch01.pdf
     文件       14778  2001-09-19 12:54  answers\ch02.pdf
     文件       15330  2001-09-19 12:55  answers\ch03.pdf
     文件       29060  2001-09-19 12:55  answers\ch04.pdf
     文件       13390  2001-09-19 12:55  answers\ch05.pdf
     文件       32039  2001-09-19 12:55  answers\ch06.pdf
     文件       22231  2001-09-19 12:55  answers\ch07.pdf
     文件       14724  2001-09-19 12:55  answers\ch08.pdf
     文件       42865  2001-09-19 12:55  answers\ch09.pdf
     文件       45488  2001-09-19 12:56  answers\ch10.pdf
     文件       13333  2001-09-19 12:56  answers\ch11.pdf
     文件        4435  2001-09-19 12:56  answers\ch12.pdf
     目录           0  2017-06-23 21:00  codes\
     文件        6181  1996-08-13 03:27  codes\aatree.c
     文件         669  1997-11-05 09:33  codes\aatree.h
     文件        5593  1996-08-13 03:27  codes\avltree.c
     文件         583  1997-11-05 09:34  codes\avltree.h
     文件        3364  1996-08-13 03:27  codes\binheap.c
     文件         588  1997-11-05 09:34  codes\binheap.h
     文件        6727  1996-08-13 03:27  codes\binomial.c
     文件         762  1997-11-05 09:34  codes\binomial.h
     文件        4474  1996-08-13 03:27  codes\cursor.c
     文件         890  1997-11-05 09:35  codes\cursor.h
     文件        2564  1996-08-13 03:27  codes\disjsets.c
     文件        4737  1996-08-13 03:27  codes\dsl.c
     文件         701  1997-11-05 09:35  codes\dsl.h
     文件         156  2008-08-11 20:03  codes\fatal.h
     文件         848  1996-08-13 03:27  codes\fig10_38.c
     文件         808  1996-08-13 03:27  codes\fig10_40.c
............此处省略60个文件信息

评论

共有 条评论