Compare commits
No commits in common. "a1a0bc1a2fb5e1132793bf93e0ddd6432a4e5578" and "a9012274015f510706576d23b30242cdc82ab628" have entirely different histories.
a1a0bc1a2f
...
a901227401
192
4x.cpp
192
4x.cpp
|
@ -1,192 +0,0 @@
|
||||||
#ifndef __PROGTEST__
|
|
||||||
#include <cstdio>
|
|
||||||
#include <cstdlib>
|
|
||||||
#include <cstring>
|
|
||||||
#include <cctype>
|
|
||||||
#include <cassert>
|
|
||||||
#include <iostream>
|
|
||||||
#include <iomanip>
|
|
||||||
#include <sstream>
|
|
||||||
#include <stdexcept>
|
|
||||||
#include <string>
|
|
||||||
#include <list>
|
|
||||||
#include <vector>
|
|
||||||
#include <stack>
|
|
||||||
#include <queue>
|
|
||||||
#include <deque>
|
|
||||||
#include <map>
|
|
||||||
#include <unordered_map>
|
|
||||||
#include <set>
|
|
||||||
#include <unordered_set>
|
|
||||||
#include <algorithm>
|
|
||||||
#include <memory>
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
class Cbase {
|
|
||||||
public:
|
|
||||||
Cbase(string sector, string species, int when) : m_Sector(std::move(sector)), m_Species(std::move(species)), m_When(when) {}
|
|
||||||
~Cbase() = default;
|
|
||||||
|
|
||||||
string m_Sector;
|
|
||||||
string m_Species;
|
|
||||||
int m_When;
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /* __PROGTEST__ */
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class CUniverse {
|
|
||||||
public:
|
|
||||||
using Race = std::string;
|
|
||||||
using Sector = std::string;
|
|
||||||
using Time = int;
|
|
||||||
|
|
||||||
CUniverse & addConnection(const string & from, const string & to) {
|
|
||||||
_s[from].push_back(to);
|
|
||||||
_s[to].push_back(from);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
CUniverse & optimize() {
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
map<string, string> colonise(const vector<Cbase> & bases) const {
|
|
||||||
std::queue< std::tuple< Sector, Time, Race > > q;
|
|
||||||
std::map< Sector, std::tuple< Time, Race, bool > > d;
|
|
||||||
|
|
||||||
for (auto& i : bases) {
|
|
||||||
q.emplace(i.m_Sector, i.m_When, i.m_Species);
|
|
||||||
d[i.m_Sector] = {i.m_When, i.m_Species, true};
|
|
||||||
}
|
|
||||||
|
|
||||||
while (q.size()) {
|
|
||||||
auto i = q.front();
|
|
||||||
q.pop();
|
|
||||||
if (d.at( std::get<0>(i) ) == std::tuple< Time, Race, bool >(0, "", true)) continue;
|
|
||||||
|
|
||||||
auto it = _s.find(std::get<0>(i));
|
|
||||||
if (it == _s.end()) continue;
|
|
||||||
|
|
||||||
for (const Sector& adj : it->second) {
|
|
||||||
auto itd = d.find(adj);
|
|
||||||
if (itd == d.end()) { // nenalezena
|
|
||||||
q.emplace( adj, std::get<1>(i) + 1, std::get<2>(i) );
|
|
||||||
d[adj] = { std::get<1>(i) + 1, std::get<2>(i), false};
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
//nalezena
|
|
||||||
if (std::get<2>(itd->second)) continue; // startovaci planeta
|
|
||||||
|
|
||||||
if (std::get<0>(itd->second) == std::get<1>(i) + 1) { // srazka
|
|
||||||
d[adj] = {0, "", true};
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (std::get<0>(itd->second) > std::get<1>(i) + 1) {
|
|
||||||
q.emplace( adj, std::get<1>(i) + 1, std::get<2>(i) );
|
|
||||||
d[adj] = { std::get<1>(i) + 1, std::get<2>(i), false};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
map<string, string> ret;
|
|
||||||
for (const auto& i : d) {
|
|
||||||
if (i.second == std::tuple< Time, Race, bool >(0, "", true)) continue;
|
|
||||||
ret[i.first] = std::get<1>(i.second);
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::map< Sector, std::vector< Sector > > _s;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef __PROGTEST__
|
|
||||||
|
|
||||||
int main ( void ) {
|
|
||||||
CUniverse u1;
|
|
||||||
|
|
||||||
u1 .addConnection("Earth", "X1")
|
|
||||||
.addConnection("Earth", "Y1")
|
|
||||||
.addConnection("Vulcan", "X1")
|
|
||||||
.addConnection("Vulcan", "Y2")
|
|
||||||
.addConnection("Y2", "Y1")
|
|
||||||
.addConnection("Kronos", "X1")
|
|
||||||
.addConnection("X1", "X2")
|
|
||||||
.addConnection("X2", "X3")
|
|
||||||
.optimize();
|
|
||||||
|
|
||||||
auto r1 = u1.colonise({{"Earth", "Humans", 0}, {"Vulcan", "Vulcans", 0}, {"Kronos", "Clingons", 0}});
|
|
||||||
assert(r1 == (map<string, string> ({{"Earth", "Humans"}, {"Y1", "Humans"}, {"Vulcan", "Vulcans"}, {"Y2", "Vulcans"}, {"Kronos", "Clingons"}})));
|
|
||||||
auto r2 = u1.colonise({{"Earth", "Humans", 0}, {"Vulcan", "Vulcans", 0}, {"Kronos", "Humans", 0}});
|
|
||||||
assert(r2 == (map<string, string> ({{"Earth", "Humans"}, {"Y1", "Humans"}, {"Vulcan", "Vulcans"}, {"Y2", "Vulcans"}, {"Kronos", "Humans"}})));
|
|
||||||
auto r3 = u1.colonise({{"Unknown", "Unknown", 0}});
|
|
||||||
assert(r3 == (map<string, string> ({{"Unknown", "Unknown"}})));
|
|
||||||
auto r4 = u1.colonise({});
|
|
||||||
assert(r4 == (map<string, string>({})));
|
|
||||||
|
|
||||||
|
|
||||||
CUniverse u2;
|
|
||||||
|
|
||||||
u2 .addConnection("Earth", "Z1")
|
|
||||||
.addConnection("Earth", "Y1")
|
|
||||||
.addConnection("Earth", "Kronos")
|
|
||||||
.addConnection("Earth", "Vulcan")
|
|
||||||
.addConnection("Vulcan", "Y3")
|
|
||||||
.addConnection("Vulcan", "X1")
|
|
||||||
.addConnection("Kronos", "Z2")
|
|
||||||
.addConnection("Kronos", "X4")
|
|
||||||
.addConnection("Kronos", "Vulcan")
|
|
||||||
.addConnection("Y1", "Y2")
|
|
||||||
.addConnection("Y2", "Y3")
|
|
||||||
.addConnection("Z1", "Z2")
|
|
||||||
.addConnection("X1", "X2")
|
|
||||||
.addConnection("X2", "X3")
|
|
||||||
.addConnection("X1", "X3")
|
|
||||||
.addConnection("X3", "X4")
|
|
||||||
.addConnection("Bajor", "Cassiopea Prime")
|
|
||||||
.optimize();
|
|
||||||
|
|
||||||
auto r5 = u2.colonise({{"Earth", "Humans", 0}, {"Vulcan", "Vulcans", 0}, {"Kronos", "Clingons", 0}, {"Cassiopea Prime", "Cassiopeans", 0}});
|
|
||||||
assert(r5 == (map<string, string> ({{"Earth", "Humans"}, {"Kronos", "Clingons"}, {"Vulcan", "Vulcans"}, {"Cassiopea Prime", "Cassiopeans"}, {"Bajor", "Cassiopeans"}, {"Z1", "Humans"}, {"Z2", "Clingons"}, {"Y1", "Humans"}, {"Y3", "Vulcans"}, {"X1", "Vulcans"}, {"X2", "Vulcans"}, {"X4", "Clingons"}})));
|
|
||||||
|
|
||||||
//Harder tests when != 0 for all colonies
|
|
||||||
CUniverse u3;
|
|
||||||
|
|
||||||
u3 .addConnection("Earth", "Z1")
|
|
||||||
.addConnection("Earth", "Y1")
|
|
||||||
.addConnection("Earth", "Kronos")
|
|
||||||
.addConnection("Earth", "Vulcan")
|
|
||||||
.addConnection("Vulcan", "Y3")
|
|
||||||
.addConnection("Vulcan", "X1")
|
|
||||||
.addConnection("Kronos", "Z2")
|
|
||||||
.addConnection("Kronos", "X4")
|
|
||||||
.addConnection("Y1", "Y2")
|
|
||||||
.addConnection("Y2", "Y3")
|
|
||||||
.addConnection("Z1", "Z2")
|
|
||||||
.addConnection("X1", "X2")
|
|
||||||
.addConnection("X1", "X3")
|
|
||||||
.addConnection("X2", "X3")
|
|
||||||
.addConnection("X3", "X4")
|
|
||||||
.addConnection("Bajor", "Cassiopea Prime")
|
|
||||||
.optimize();
|
|
||||||
|
|
||||||
auto r8 = u3.colonise({{"Earth", "Humans", 1}, {"Vulcan", "Vulcans", 0}, {"Kronos", "Clingons", 2}, {"Cassiopea Prime", "Cassiopeans", 10000}});
|
|
||||||
assert(r8 == (map<string, string> ({{"Earth", "Humans"}, {"Kronos", "Clingons"}, {"Vulcan", "Vulcans"}, {"Y1", "Humans"}, {"Z1", "Humans"}, {"Y3", "Vulcans"}, {"Y2", "Vulcans"}, {"X1", "Vulcans"}, {"X2", "Vulcans"}, {"X3", "Vulcans"}, {"Cassiopea Prime", "Cassiopeans"}, {"Bajor", "Cassiopeans"}})));
|
|
||||||
|
|
||||||
std::cout << "success!\n";
|
|
||||||
return EXIT_SUCCESS;
|
|
||||||
}
|
|
||||||
#endif /* __PROGTEST__ */
|
|
171
pkg.cpp
171
pkg.cpp
|
@ -1,171 +0,0 @@
|
||||||
#include <iostream>
|
|
||||||
#include <cassert>
|
|
||||||
#include <vector>
|
|
||||||
#include <set>
|
|
||||||
#include <map>
|
|
||||||
#include <string>
|
|
||||||
#include <unordered_map>
|
|
||||||
#include <memory>
|
|
||||||
#include <unordered_set>
|
|
||||||
#include <queue>
|
|
||||||
#include <list>
|
|
||||||
#include <sstream>
|
|
||||||
#include <cstring>
|
|
||||||
|
|
||||||
#include <stack>
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
class CPkg{
|
|
||||||
public:
|
|
||||||
CPkg( std::string n )
|
|
||||||
: _name(std::move(n)) {}
|
|
||||||
CPkg& addDep( std::string n ) {
|
|
||||||
_deps.emplace_back( std::move(n) );
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
bool operator<( const CPkg& oth ) const {
|
|
||||||
return _name < oth._name;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string _name;
|
|
||||||
std::vector< std::string > _deps;
|
|
||||||
private:
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
class CPkgSys{
|
|
||||||
public:
|
|
||||||
CPkgSys& addPkg(const CPkg& p) {
|
|
||||||
packages[p._name] = p._deps;
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
std::set<std::string> install(std::list<std::string> what) {
|
|
||||||
std::set<std::string> d = installed;
|
|
||||||
std::queue<std::string> q;
|
|
||||||
std::set<std::string> r;
|
|
||||||
|
|
||||||
for (const auto& i : what) {
|
|
||||||
q.push(i);
|
|
||||||
if (d.emplace(i).second)
|
|
||||||
r.emplace(i);
|
|
||||||
}
|
|
||||||
|
|
||||||
while (q.size()) {
|
|
||||||
auto i = q.front();
|
|
||||||
q.pop();
|
|
||||||
auto it = packages.find(i);
|
|
||||||
|
|
||||||
if (it == packages.end())
|
|
||||||
throw std::invalid_argument("Package not found.");
|
|
||||||
|
|
||||||
for ( const auto& j : it->second ) {
|
|
||||||
if (d.emplace(j).second) {
|
|
||||||
r.emplace(j);
|
|
||||||
q.push(j);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
std::swap( installed, d );
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
private:
|
|
||||||
std::unordered_map<std::string, std::vector<std::string>> packages;
|
|
||||||
std::set<std::string> installed;
|
|
||||||
};
|
|
||||||
|
|
||||||
int main(void){
|
|
||||||
CPkgSys s;
|
|
||||||
stringstream ss;
|
|
||||||
s.addPkg(CPkg("ssh").addDep("sudo").addDep("apt"))
|
|
||||||
.addPkg(CPkg("sudo").addDep("git").addDep("c++"));
|
|
||||||
s.addPkg(CPkg("apt"))
|
|
||||||
.addPkg(CPkg("c++").addDep("c").addDep("asm").addDep("fortran"));
|
|
||||||
s.addPkg(CPkg("git"))
|
|
||||||
.addPkg(CPkg("c").addDep("kekw"))
|
|
||||||
.addPkg(CPkg("kekw"))
|
|
||||||
.addPkg(CPkg("asm"))
|
|
||||||
.addPkg(CPkg("fortran"));
|
|
||||||
s.addPkg(CPkg("python").addDep("bash").addDep("sadge"))
|
|
||||||
.addPkg(CPkg("karel").addDep("python"))
|
|
||||||
.addPkg(CPkg("bash").addDep("sadge"))
|
|
||||||
.addPkg(CPkg("sadge"))
|
|
||||||
.addPkg(CPkg("cython").addDep("dev"));
|
|
||||||
s.addPkg(CPkg("perl"));
|
|
||||||
|
|
||||||
// ss << s;
|
|
||||||
// assert(ss.str() == "");
|
|
||||||
ss.clear();
|
|
||||||
ss.str("");
|
|
||||||
|
|
||||||
set<string> t1 = s.install(list<string> {"sudo"});
|
|
||||||
assert(t1 == (set<string> {"asm", "c", "c++", "fortran", "git", "kekw", "sudo"}));
|
|
||||||
set<string> t2 = s.install(list<string> {"ssh", "c++"});
|
|
||||||
assert(t2 == (set<string> {"apt", "ssh"}));
|
|
||||||
|
|
||||||
// ss << s;
|
|
||||||
// assert(ss.str() == "apt, asm, c, c++, fortran, git, kekw, ssh, sudo");
|
|
||||||
// ss.clear();
|
|
||||||
// ss.str("");
|
|
||||||
|
|
||||||
try{
|
|
||||||
set<string> e = s.install(list<string> {"karel", "cython"});
|
|
||||||
assert("Sem ses nemel dostat debilku" == nullptr);
|
|
||||||
}
|
|
||||||
catch(const invalid_argument & e){
|
|
||||||
assert(strcmp("Package not found.", e.what()) == 0);
|
|
||||||
}
|
|
||||||
set<string> t3 = s.install(list<string> {"karel", "fortran", "git"});
|
|
||||||
assert(t3 == (set<string> {"bash", "karel", "python", "sadge"}));
|
|
||||||
|
|
||||||
s.addPkg(CPkg("java").addDep("utils"))
|
|
||||||
.addPkg(CPkg("utils").addDep("VB"))
|
|
||||||
.addPkg(CPkg("VB").addDep("java"));
|
|
||||||
|
|
||||||
set<string> t4 = s.install(list<string> {"java", "perl"});
|
|
||||||
assert(t4 == (set<string> {"VB", "java", "perl", "utils"}));
|
|
||||||
|
|
||||||
// ss << s;
|
|
||||||
// assert(ss.str() == "VB, apt, asm, bash, c, c++, fortran, git, java, karel, kekw, perl, python, sadge, ssh, sudo, utils");
|
|
||||||
// ss.clear();
|
|
||||||
// ss.str("");
|
|
||||||
|
|
||||||
CPkgSys k;
|
|
||||||
k.addPkg(CPkg("ssh").addDep("sudo").addDep("apt"))
|
|
||||||
.addPkg(CPkg("sudo").addDep("git"));
|
|
||||||
k.addPkg(CPkg("apt"));
|
|
||||||
k.addPkg(CPkg("git"))
|
|
||||||
.addPkg(CPkg("c").addDep("kekw"))
|
|
||||||
.addPkg(CPkg("kekw"))
|
|
||||||
.addPkg(CPkg("asm"))
|
|
||||||
.addPkg(CPkg("fortran"));
|
|
||||||
k.addPkg(CPkg("python").addDep("bash").addDep("sadge"))
|
|
||||||
.addPkg(CPkg("karel").addDep("python"))
|
|
||||||
.addPkg(CPkg("bash").addDep("sadge"))
|
|
||||||
.addPkg(CPkg("sadge"));
|
|
||||||
k.addPkg(CPkg("perl").addDep("no"));
|
|
||||||
|
|
||||||
set<string> t5 = k.install(list<string> {"asm"});
|
|
||||||
assert(t5 == (set<string> {"asm"}));
|
|
||||||
set<string> t6 = k.install(list<string> {"python", "ssh"});
|
|
||||||
assert(t6 == (set<string> {"apt", "bash", "git", "python", "sadge", "ssh", "sudo"}));
|
|
||||||
|
|
||||||
try{
|
|
||||||
set<string> t7 = k.install(list<string> {"perl", "c"});
|
|
||||||
assert("Sem ses nemel dostat debilku" == nullptr);
|
|
||||||
}
|
|
||||||
catch(const invalid_argument & e){
|
|
||||||
assert(strcmp("Package not found.", e.what()) == 0);
|
|
||||||
}
|
|
||||||
set<string> t8 = k.install(list<string> {"c", "ssh", "karel"});
|
|
||||||
|
|
||||||
assert(t8 == (set<string> {"c", "karel", "kekw"}));
|
|
||||||
|
|
||||||
// ss << k;
|
|
||||||
// assert(ss.str() == "apt, asm, bash, c, git, karel, kekw, python, sadge, ssh, sudo");
|
|
||||||
// ss.clear();
|
|
||||||
// ss.str("");
|
|
||||||
std::cout << "success!\n";
|
|
||||||
}
|
|
Loading…
Reference in New Issue