Beispiel #1
0
 def test_pushpop(self):
     heap = OrderHeap(reversed(ascii_lowercase), key=self.key)
     for u, l in reversed(list(zip(ascii_uppercase, ascii_lowercase))):
         popped_item = heap.pushpop(u)
         heap.check()
         self.assertEqual(l, popped_item)
     self.assertSetEqual(set(ascii_uppercase), set(heap))
Beispiel #2
0
 def test_pop(self):
     heap = OrderHeap(reversed(ascii_uppercase), key=self.key)
     sorted_items = []
     for c in reversed(ascii_uppercase):
         popped_item = heap.pop()
         heap.check()
         self.assertEqual(c, popped_item)
         sorted_items.append(popped_item)
     self.assertSequenceEqual(list(reversed(ascii_uppercase)), sorted_items)
     self.assertSetEqual(set(), set(heap))
Beispiel #3
0
 def test_push(self):
     heap = OrderHeap([], key=self.key)
     wanted = set()
     not_wanted = set(ascii_uppercase)
     for c in reversed(ascii_uppercase):
         heap.push(c)
         wanted.add(c)
         not_wanted.remove(c)
         self.assertHeap(wanted, not_wanted, heap)
     self.assertHeap(ascii_uppercase, [], heap)
Beispiel #4
0
 def test_push(self):
     heap = OrderHeap([], key=self.key)
     wanted = set()
     not_wanted = set(ascii_uppercase)
     for c in reversed(ascii_uppercase):
         heap.push(c)
         wanted.add(c)
         not_wanted.remove(c)
         self.assertHeap(wanted, not_wanted, heap)
     self.assertHeap(ascii_uppercase, [], heap)
Beispiel #5
0
 def test_pushpop(self):
     heap = OrderHeap(reversed(ascii_lowercase), key=self.key)
     wanted = set(ascii_lowercase)
     not_wanted = set()
     for u, l in reversed(list(zip(ascii_uppercase, ascii_lowercase))):
         self.assertEqual(l, heap.pushpop(u))
         wanted.add(u)
         wanted.remove(l)
         not_wanted.add(l)
         self.assertHeap(wanted, not_wanted, heap)
     self.assertHeap(ascii_uppercase, ascii_lowercase, heap)
Beispiel #6
0
 def test_pushpop(self):
     heap = OrderHeap(reversed(ascii_lowercase), key=self.key)
     wanted = set(ascii_lowercase)
     not_wanted = set()
     for u, l in reversed(list(zip(ascii_uppercase, ascii_lowercase))):
         self.assertEqual(l, heap.pushpop(u))
         wanted.add(u)
         wanted.remove(l)
         not_wanted.add(l)
         self.assertHeap(wanted, not_wanted, heap)
     self.assertHeap(ascii_uppercase, ascii_lowercase, heap)
Beispiel #7
0
 def test_pop(self):
     heap = OrderHeap(reversed(ascii_uppercase), key=self.key)
     wanted = set(ascii_uppercase)
     not_wanted = set()
     sorted_items = []
     for c in reversed(ascii_uppercase):
         self.assertEqual(c, heap.pop())
         wanted.remove(c)
         not_wanted.add(c)
         self.assertHeap(wanted, not_wanted, heap)
         sorted_items.append(c)
     self.assertSequenceEqual(list(reversed(ascii_uppercase)), sorted_items)
     self.assertHeap([], ascii_uppercase, heap)
Beispiel #8
0
 def test_pop(self):
     heap = OrderHeap(reversed(ascii_uppercase), key=self.key)
     wanted = set(ascii_uppercase)
     not_wanted = set()
     sorted_items = []
     for c in reversed(ascii_uppercase):
         self.assertEqual(c, heap.pop())
         wanted.remove(c)
         not_wanted.add(c)
         self.assertHeap(wanted, not_wanted, heap)
         sorted_items.append(c)
     self.assertSequenceEqual(list(reversed(ascii_uppercase)), sorted_items)
     self.assertHeap([], ascii_uppercase, heap)
Beispiel #9
0
def solve():
  N, K = map(int, input().split())
  max_heap = OrderHeap([], lambda key: -key)

  unique = set()
  cnt = defaultdict(int)

  max_heap.push(N)
  cnt[N] = 1

  while len(max_heap) > 0:
    val = max_heap.pop()
    nr = cnt[val]

    if K <= nr:
      return (val - 1 - (val-1)//2, (val - 1) // 2)
    else:
      K -= nr

    unique.add(val)
    l = [(val-1)//2, val - 1 - (val-1)//2]
    for el in l:
      if el:
        if cnt[el] is 0:
          max_heap.push(el)
        cnt[el] += nr
Beispiel #10
0
 def test_push(self):
     heap = OrderHeap([], key=self.key)
     for c in reversed(ascii_uppercase):
         heap.push(c)
         heap.check()
     self.assertSetEqual(set(ascii_uppercase), set(heap))
Beispiel #11
0
 def test_peek(self):
     heap = OrderHeap(reversed(ascii_uppercase), key=self.key)
     self.assertEqual('Z', heap.peek())
Beispiel #12
0
 def test_remove_not_implemented(self):
     heap = OrderHeap(reversed(ascii_uppercase), key=self.key)
     self.assertRaises(NotImplementedError, heap.remove, 'A')
Beispiel #13
0
 def test_repr(self):
     heap = OrderHeap(reversed(ascii_uppercase), key=self.key)
     self.assertHeap(heap, [], eval(re.sub(r'key=<.*>', 'key=self.key', repr(heap))))
Beispiel #14
0
 def test_init(self):
     self.assertHeap([], [], OrderHeap(key=self.key))
     self.assertHeap([], [], OrderHeap([], key=self.key))
     self.assertHeap(ascii_uppercase, [], OrderHeap(ascii_uppercase, key=self.key))
Beispiel #15
0
 def test_pushpop_on_empty_heap(self):
     self.assertEqual('A', OrderHeap(key=self.key).pushpop('A'))
Beispiel #16
0
 def test_check(self):
     OrderHeap([], key=self.key).check()
     OrderHeap(ascii_uppercase, key=self.key).check()
     OrderHeap(reversed(ascii_uppercase), key=self.key).check()
Beispiel #17
0
 def test_check_variant_invalid(self):
     heap = OrderHeap(ascii_uppercase, key=self.key)
     heap[3] = (self.key('t'), 't')
     self.assertRaises(InvalidHeapError, heap.check)
Beispiel #18
0
 def test_peek(self):
     heap = OrderHeap(reversed(ascii_uppercase), key=self.key)
     self.assertEqual('Z', heap.peek())