Submission #26747

#TimeUsernameProblemLanguageResultExecution timeMemory
26747model_codeProgramming Contest (POI11_pro)C++11
100 / 100
56 ms3016 KiB
/************************************************************************* * * * XVIII Olimpiada Informatyczna * * * * Zadanie: Konkurs programistyczny * * Autor: Pawel Parys * * Zlozonosc czasowa: O(mk) = O(m^2 * n) * * Opis: Rozwiazanie lepsze niz wzorcowe * * przez znajdowanie najlepszych sciezek * * powiekszajacych; zaczynamy od osob, BFS-em, * * konczymy jak znajdziemy wolne zadanie + * * optymalizacja przydzielajaca na poczatek po * * jednym zadaniu) * * * *************************************************************************/ #include <cstdio> #include <vector> #include <queue> #define REP(a,n) for (int a=0; a<(n); ++a) using namespace std; template<class T> int size(const T &t) { return t.size(); } typedef vector<int> vi; #define PB push_back ///////////////////////////////////////// int No, Nz, maxZ; int zad2os_u[500]; // skojarzenie zadañ, -1 = brak vi os2zad_nu[500]; // od osób do nieskojarzonych z nim zadañ int os_status[500]; // 0 = dziala metoda uproszczona, 1 = zwykla, 2 = juz nic sie nie da int back_zad[500], back_os[500]; // poprzednik w bfs, -1 = nieosi±gniêty int back_zadnr[500]; // nasz numer w wektorze poprzednika int os_ile[500]; // ile osoba ma zadan (liczone tylko na koniec) queue<int> Q; // numery osob // czy¶ci tablice po BFS void czyscBFS() { REP(z, Nz) back_zad[z] = -1; REP(o, No) back_os[o] = -1; while (!Q.empty()) Q.pop(); } int main() { int R, T, K; scanf("%d%d%d%d%d", &No, &Nz, &R, &T, &K); maxZ = T/R; REP(a, Nz) zad2os_u[a] = -1; REP(a, K) { int o, z; scanf("%d%d", &o, &z); --o; --z; os2zad_nu[o].PB(z); } czyscBFS(); // przydzielanie REP(krok, maxZ) { bool ch = false; REP(o0, No) { if (os_status[o0]==2) continue; // metoda uproszczona (na pocz±tku) // przydzielaj nieuzyte zadanie w odleglosci jeden if (os_status[o0]==0) { int ok = false; REP(nr, size(os2zad_nu[o0])) { int z = os2zad_nu[o0][nr]; if (zad2os_u[z]>=0) continue; zad2os_u[z] = o0; int last = size(os2zad_nu[o0])-1; os2zad_nu[o0][nr] = os2zad_nu[o0][last]; os2zad_nu[o0].resize(last); ch = true; ok = true; break; } if (ok) continue; os_status[o0] = 1; } // metoda zwykla // BFSem szukaj nieuzytego zadania Q.push(o0); int z; while (!Q.empty()) { int o = Q.front(); Q.pop(); REP(nr, size(os2zad_nu[o])) { z = os2zad_nu[o][nr]; if (back_zad[z]>=0) continue; // juz tam bylismy back_zad[z] = o; back_zadnr[z] = nr; int o2 = zad2os_u[z]; if (o2<0) // zadanie wolne goto udalosie; if (back_os[o2]>=0) continue; // juz tam bylismy back_os[o2] = z; Q.push(o2); } } // nie udalo sie nic znalezc os_status[o0] = 2; // koniec continue; udalosie: // znalezc sciezke powiekszajaca // dodajemy j± do istniej±cego skojarzenia // na z jest docelowe zadanie zad2os_u[z] = back_zad[z]; while (back_zad[z]!=o0) { int po = back_zad[z]; int pz = back_os[po]; os2zad_nu[po][back_zadnr[z]] = pz; z = pz; zad2os_u[z] = back_zad[z]; } int last = size(os2zad_nu[o0])-1; os2zad_nu[o0][back_zadnr[z]] = os2zad_nu[o0][last]; os2zad_nu[o0].resize(last); ch = true; czyscBFS(); } if (!ch) break; } // wypisywanie wyniku int ile = 0, res = 0; REP(z, Nz) if (zad2os_u[z]>=0) ++os_ile[zad2os_u[z]]; REP(o, No) { int x = os_ile[o]; ile += x; res += x*(x+1)/2; } printf("%d %d\n", ile, res*R); REP(z, Nz) if (zad2os_u[z]>=0) { int o = zad2os_u[z]; printf("%d %d %d\n", o+1, z+1, (--os_ile[o])*R); } }

Compilation message (stderr)

pro.cpp: In function 'int main()':
pro.cpp:58:43: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  scanf("%d%d%d%d%d", &No, &Nz, &R, &T, &K);
                                           ^
pro.cpp:65:24: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d%d", &o, &z);
                        ^
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...