From ccb9099cce0b0fb04181364eb6fd4f42452adf50 Mon Sep 17 00:00:00 2001 From: Xuefeng-Zhu Date: Wed, 13 May 2015 22:05:10 -0500 Subject: [PATCH] simpligy parent, leftchild, and rightchild method --- heaps/minheap.py | 19 +++++++------------ 1 file changed, 7 insertions(+), 12 deletions(-) diff --git a/heaps/minheap.py b/heaps/minheap.py index c43a32d..144e4cb 100644 --- a/heaps/minheap.py +++ b/heaps/minheap.py @@ -11,7 +11,7 @@ def __init__(self, nums=None): self.heap = [] if nums: self.build_heap(nums) - + def __str__(self): return "Min-heap with %s items" % (len(self.heap)) @@ -19,7 +19,7 @@ def max_elements(self): return len(self.heap) def height(self): - return math.ceil(math.log(len(self.heap))/math.log(2)) + return math.ceil(math.log(len(self.heap)) / math.log(2)) def is_leaf(self, i): """ returns True if i is a leaf node """ @@ -29,18 +29,14 @@ def parent(self, i): if i == 0: return [] elif i % 2 != 0: # odd - return (i-1)/2 - return int(math.floor((i-1)/2)) + return (i - 1) / 2 + return (i - 2) / 2 def leftchild(self, i): - if not self.is_leaf(i): - return 2*i+1 - return [] + return 2 * i + 1 def rightchild(self, i): - if not self.is_leaf(i): - return 2*i+2 - return [] + return 2 * i + 2 def heapify(self, i): l = self.leftchild(i) @@ -60,8 +56,7 @@ def build_heap(self, elem): self.heap = elem[:] last_leaf = int(math.ceil( (len(self.heap)- 2) / 2)) for i in range(last_leaf, -1, -1): - self.heapify(i) - + self.heapify(i) def heappush(self, x): """ Adds a new item x in the heap"""