Cod sursa(job #1364605)

Utilizator retrogradLucian Bicsi retrograd Data 27 februarie 2015 19:00:41
Problema Regiuni Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 1.24 kb
#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;
}