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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
|
#include <stdlib.h>
#include <stdio.h>
#include <time.h>
#include "cmap.h"
#include "cvector.h"
#include "cstring.h"
#include "hash_set.hpp"
#include <unordered_map>
declare_CMap(ii, int, int);
declare_CStringVector(s);
int main()
{
CMap_ii map = cmap_initializer;
uint64_t checksum = 0;
clock_t before, difference;
size_t fib1, fib2, fibx;
const size_t N = 10000000;
printf("Starting\n");
//cmap_ii_reserve(&map, N * 1.7);
before = clock();
fib1 = 0, fib2 = 1;
for (size_t i = 0; i < N; ++i) {
checksum += ++cmap_ii_put(&map, FIBONACCI_NEXT, i)->value;
}
difference = clock() - before;
printf("%llu Check: %f\n", checksum, 1.0 * difference / CLOCKS_PER_SEC);
cmap_ii_destroy(&map);
std::unordered_map<int, int> map2;
before = clock();
fib1 = 0, fib2 = 1; checksum = 0;
for (size_t i = 0; i < N; ++i)
checksum += ++(map2[FIBONACCI_NEXT] = i);
difference = clock() - before;
printf("%llu Check: %f\n", checksum, 1.0 * difference / CLOCKS_PER_SEC);
map2.clear();
emhash7::HashMap<int, int> map3;
//map3.reserve(N);
before = clock();
fib1 = 0, fib2 = 1; checksum = 0;
for (size_t i = 0; i < N; ++i)
checksum += ++(*map3.insert(FIBONACCI_NEXT, i).first).second;
difference = clock() - before;
printf("%llu Check: %f\n", checksum, 1.0 * difference / CLOCKS_PER_SEC);
}
|