-
Notifications
You must be signed in to change notification settings - Fork 1
/
Rainbow.h
45 lines (37 loc) · 1.16 KB
/
Rainbow.h
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
//
// Created by antoine on 08/10/18.
//
#ifndef TP2_INFO901_ARCENCIEL_H
#define TP2_INFO901_ARCENCIEL_H
#include <vector>
#include "Context.h"
using namespace std;
struct Chain {
uint64 idx1; // premier indice de la chaine
uint64 idxT; // dernier indice de la chaine
};
class Rainbow {
public:
uint _number; // numero de la table (ici 0, mais voir "Moult tables")
uint _M; // nombre de chaines dans la table
vector<Chain> _X; // la table elle-meme
uint _T; // taille de chaque chaine
Rainbow(){
this->_number = 0;
this->_M=0;
this->_X.clear();
this->_T = 0;
};
// Creer les M chaînes de taille T, dans le contexte ctxt
void create( Context& ctxt, int num, int M, int T );
// Tri _X suivant idxT.
void sort();
// Sauvegarde la table sur disque.
bool save( string name );
// Charge en mémoire la table à partir du disque.
void load( string name );
// Recherche dichotomique dans la table
// ( p et q sont le premier/dernier trouvé )
bool search( uint64 idx, uint & p, uint & q );
};
#endif //TP2_INFO901_ARCENCIEL_H