【C++】木の回転を3行で書く
昔考えたやつをブログ化
//npはnodeのポインタ、b=1で右回転 ch[1]は右の子、ch[0]は左の子
np rot(np t,bool b){
tie(t->ch[1-b]->ch[b],t->ch[1-b],t) = make_tuple(t,t->ch[1-b]->ch[b],t->ch[1-b]);
if(t->ch[b])update(t->ch[b]);
return update(t);
}
make_tuple
と tie
を使って簡潔にかけます
AVL 木前提のコードなので、他の平衡二分木ならもうちょっと nullptr
に対して厳密にやる必要があるかも
nullptr=hoge
という文を作っても今の所良い感じに ignore してくれてます(c++の仕様を知っているわけでは無いので知ってる方いれば教えて欲しいです)
目次