-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnh_subset.h
39 lines (28 loc) · 831 Bytes
/
nh_subset.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
#ifndef NH_SUBSET_H
#define NH_SUBSET_H
#include <vector>
#include "pattern.h"
#include "bits.h"
extern const int NH_ROW;
extern const int NH_COL;
extern const int NH_BOX;
class NHSubset : public Pattern {
public:
NHSubset(std::vector<Target> targetss, std::vector<Key> keyss, std::vector<int> valss, std::vector<Spot> subsetx, int t, int empties);
void apply(BitMatrix* bits);
void full_display(Output* out);
void display_keys(Output* out);
void describe(std::ostream& out);
std::vector<Target> target_list();
std::vector<Key> key_list();
Pattern* clone();
std::vector<Target> targets;
std::vector<Key> keys;
std::vector<int> vals;
std::vector<Spot> subset;
int type;
int empty;
};
std::ostream& operator<<(std::ostream& out, NHSubset* nh);
std::vector<NHSubset> find_nh_subsets(Bits* bits);
#endif