Hostname: page-component-77f85d65b8-t68ds Total loading time: 0 Render date: 2026-03-26T08:10:53.440Z Has data issue: false hasContentIssue false

Balancing weight-balanced trees

Published online by Cambridge University Press:  27 May 2011

YOICHI HIRAI
Affiliation:
The University of Tokyo, JSPS Research Fellow (e-mail: yh@lyon.is.s.u-tokyo.ac.jp)
KAZUHIKO YAMAMOTO
Affiliation:
IIJ Innovation Institute Inc. (e-mail: kazu@iij.ad.jp)
Rights & Permissions [Opens in a new window]

Abstract

Core share and HTML view are not available for this content. However, as you have access to this content, a full PDF is available via the 'Save PDF' action button.

A weight-balanced tree (WBT) is a binary search tree, whose balance is based on the sizes of the subtrees in each node. Although purely functional implementations on a variant WBT algorithm are widely used in functional programming languages, many existing implementations do not maintain balance after deletion in some cases. The difficulty lies in choosing a valid pair of rotation parameters: one for standard balance and the other for choosing single or double rotation. This paper identifies the exact valid range of the rotation parameters for insertion and deletion in the original WBT algorithm where one and only one integer solution exists. Soundness of the range is proved using a proof assistant Coq. Completeness is proved using effective algorithms generating counterexample trees. For two specific parameter pairs, we also proved in Coq that set operations also maintain balance. Since the difference between the original WBT and the variant WBT is small, it is easy to change the existing buggy implementations based on the variant WBT to the certified original WBT with a rational solution.

Information

Type
Articles
Copyright
Copyright © Cambridge University Press 2011
Submit a response

Discussions

No Discussions have been published for this article.