为了账号安全,请及时绑定邮箱和手机立即绑定

请问第18行是什么意思,X已经是T->left,为什么还会小于T- >left?

请问第18行是什么意思,X已经是T->left,为什么还会小于T- >left?

慕的地8271018 2023-04-24 21:17:28
AvlTreeInsert( ElementType X, AvlTree T){1 if( T == NULL)2 {3 /* Create and return a one-onde tree */4 T = malloc( sizeof( struct AvlNode ) );5 if( T == NULL )6 FatalError( "Out of space!!!");7 else8 {9 T->Element = X; T->Height = 0;10 T->Left = T->Right = NULL;11 }12 }13 else14 if( X < T->Element )15 {16 T->left = Insert(x, T->left );17 if( Height( T->left ) - Height( T->Right ) == 2 )18 if( X < T->Left->Element )19 T = SingleRotatewithLeft( T );20 else21 T = DoubleRotateWithLeft( T );22 }23 else24 if( X > T->Element )25 {26 T->Right = Insert( X, T->Right );27 if( Height( T->Right ) - Height( T->Left ) == 2 )28 if( X > T->Right->Element )29 T = SingleRotateWithRight( T );30 else31 T = DoubleRotateWithRight( T );32 }33 /* Else X is in the tree already; we'll do nothing */34 T->Height = Max( Height( T->Left ), Height( T->Right ) ) + 1;35 return T;}
查看完整描述

1 回答

?
慕工程0101907

TA贡献1887条经验 获得超5个赞

你理解错了,前面说的只是在T->left 中插入x,但是并不清楚在左子树的什么地方插入
第18行的意思是在T的左子树的左子树插入,自然是执行一个向右的单旋转来平衡,如果是在T的左子树的右子树中插入,自然执行一个先左后右的双旋转来平衡

查看完整回答
反对 回复 2023-04-27
  • 1 回答
  • 0 关注
  • 127 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信