Pagini recente » Cod sursa (job #2376292) | Cod sursa (job #662611) | Cod sursa (job #2390229) | Cod sursa (job #3229559) | Cod sursa (job #1364605)
#include<fstream>
#include<vector>
#include<bitset>
#include<unordered_map>
#include<algorithm>
using namespace std;
typedef int var;
ifstream fin("regiuni.in");
ofstream fout("regiuni.out");
const var MAXN = 1001;
const var P1 = 666013,
P2 = 123201,
P3 = 9381;
inline bool is_above(const var &x, const var &y, const var &a, const var &b, const var &c, const var &ind) {
return a*x + b*y + c > 0;
}
vector<var> H;
int main() {
var n, m, x, y;
fin>>n>>m;
var i, j;
bool rez;
var val1, val2;
var c, b, a;
for(i=1; i<=n; i++) {
fin>>a>>b>>c;
}
for(i=1; i<=m; i++) {
fin>>x>>y;
val1 = val2 = 0;
fin.seekg(ios_base::beg);
fin>>c;
fin>>c;
for(j=1; j<=n; j++) {
fin>>a>>b>>c;
rez = is_above(x, y, a, b, c, j);
val1 = val1*2 + rez;
val2 = val2*2 + rez;
val1 %= P1;
val2 %= P2;
}
if(find(H.begin(), H.end(), val1*P3+val2) == H.end()) {
H.push_back(val1*P3+val2);
}
for(j=1; j<=i; j++) {
fin>>x>>y;
}
}
fout<<H.size();
return 0;
}