-
Notifications
You must be signed in to change notification settings - Fork 1.4k
/
Copy pathBinomialHeapsTest.cs
37 lines (32 loc) · 1.03 KB
/
BinomialHeapsTest.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
using DataStructures.Heaps;
using Xunit;
namespace UnitTest.DataStructuresTests
{
public static class BinomialHeapsTest
{
[Fact]
public static void DoTest()
{
int i = 37;
int numberOfItems = 100000;
BinomialMinHeap<int> firstHeap = new BinomialMinHeap<int>();
BinomialMinHeap<int> secondHeap = new BinomialMinHeap<int>();
BinomialMinHeap<int> thirdHeap = new BinomialMinHeap<int>();
for (i = 37; i != 0; i = (i + 37) % numberOfItems)
{
if (i % 2 == 0)
secondHeap.Add(i);
else
firstHeap.Add(i);
}
firstHeap.Merge(secondHeap);
thirdHeap = firstHeap;
for (i = 1; i <= thirdHeap.Count; i++)
{
var min = thirdHeap.ExtractMin();
Assert.True(min == i, "WRONG MIN");
}
Assert.True(secondHeap.IsEmpty, "SECOND HEAP SHOULD BE EMPTY");
}
}
}