mid-kid
2 years ago
4 changed files with 610 additions and 1 deletions
@ -0,0 +1,96 @@ |
|||
#include <iostream> |
|||
#include <vector> |
|||
#include <algorithm> |
|||
|
|||
using namespace std; |
|||
|
|||
struct Instr { |
|||
unsigned count; |
|||
unsigned orig; |
|||
unsigned dest; |
|||
}; |
|||
|
|||
struct Input { |
|||
vector<vector<char>> stacks; |
|||
vector<Instr> instrs; |
|||
}; |
|||
|
|||
vector<vector<char>> parse_stacks() |
|||
{ |
|||
vector<vector<char>> data; |
|||
for (string line; getline(cin, line);) { |
|||
if (line.empty()) break; |
|||
unsigned count = (line.size() + 1) / 4; |
|||
while (data.size() < count) data.resize(count); |
|||
for (unsigned i = 0; i < count; i++) { |
|||
auto pos = line.begin() + i * 4; |
|||
if (pos[0] == '[' && pos[2] == ']') data[i].push_back(pos[1]); |
|||
} |
|||
} |
|||
for (auto &x : data) reverse(x.begin(), x.end()); |
|||
return data; |
|||
} |
|||
|
|||
vector<Instr> parse_instrs() |
|||
{ |
|||
vector<Instr> data; |
|||
for (string line; getline(cin, line);) { |
|||
Instr cur; |
|||
sscanf(line.c_str(), "move %u from %u to %u", |
|||
&cur.count, &cur.orig, &cur.dest); |
|||
data.push_back(cur); |
|||
} |
|||
return data; |
|||
} |
|||
|
|||
Input parse() |
|||
{ |
|||
Input data; |
|||
data.stacks = parse_stacks(); |
|||
data.instrs = parse_instrs(); |
|||
return data; |
|||
} |
|||
|
|||
string p1(const Input &input) |
|||
{ |
|||
auto stacks = input.stacks; |
|||
for (auto &instr : input.instrs) { |
|||
auto &o = stacks.at(instr.orig - 1); |
|||
auto &d = stacks.at(instr.dest - 1); |
|||
if (o.size() < instr.count) throw "instr error"; |
|||
for (unsigned i = 0; i < instr.count; i++) { |
|||
d.push_back(o.back()); |
|||
o.pop_back(); |
|||
} |
|||
} |
|||
|
|||
string out; |
|||
for (auto &s : stacks) out.push_back(s.back()); |
|||
return out; |
|||
} |
|||
|
|||
string p2(const Input &input) |
|||
{ |
|||
auto stacks = input.stacks; |
|||
for (auto &instr : input.instrs) { |
|||
auto &o = stacks.at(instr.orig - 1); |
|||
auto &d = stacks.at(instr.dest - 1); |
|||
if (o.size() < instr.count) throw "instr error"; |
|||
// std::copy maybe?
|
|||
for (unsigned i = 0; i < instr.count; i++) { |
|||
d.push_back(*(o.end() - instr.count + i)); |
|||
} |
|||
o.resize(o.size() - instr.count); |
|||
} |
|||
|
|||
string out; |
|||
for (auto &s : stacks) out.push_back(s.back()); |
|||
return out; |
|||
} |
|||
|
|||
int main() |
|||
{ |
|||
Input input = parse(); |
|||
cout << p1(input) << endl; |
|||
cout << p2(input) << endl; |
|||
} |
@ -0,0 +1,511 @@ |
|||
[Q] [J] [H] |
|||
[G] [S] [Q] [Z] [P] |
|||
[P] [F] [M] [F] [F] [S] |
|||
[R] [R] [P] [F] [V] [D] [L] |
|||
[L] [W] [W] [D] [W] [S] [V] [G] |
|||
[C] [H] [H] [T] [D] [L] [M] [B] [B] |
|||
[T] [Q] [B] [S] [L] [C] [B] [J] [N] |
|||
[F] [N] [F] [V] [Q] [Z] [Z] [T] [Q] |
|||
1 2 3 4 5 6 7 8 9 |
|||
|
|||
move 1 from 8 to 1 |
|||
move 1 from 6 to 1 |
|||
move 3 from 7 to 4 |
|||
move 3 from 2 to 9 |
|||
move 11 from 9 to 3 |
|||
move 1 from 6 to 9 |
|||
move 15 from 3 to 9 |
|||
move 5 from 2 to 3 |
|||
move 3 from 7 to 5 |
|||
move 6 from 9 to 3 |
|||
move 6 from 1 to 6 |
|||
move 2 from 3 to 7 |
|||
move 5 from 4 to 5 |
|||
move 7 from 9 to 4 |
|||
move 2 from 9 to 5 |
|||
move 10 from 4 to 2 |
|||
move 6 from 5 to 4 |
|||
move 2 from 7 to 6 |
|||
move 10 from 2 to 3 |
|||
move 21 from 3 to 5 |
|||
move 1 from 3 to 6 |
|||
move 3 from 6 to 9 |
|||
move 1 from 8 to 9 |
|||
move 5 from 4 to 5 |
|||
move 4 from 9 to 3 |
|||
move 17 from 5 to 1 |
|||
move 1 from 6 to 2 |
|||
move 16 from 5 to 1 |
|||
move 3 from 3 to 6 |
|||
move 6 from 6 to 4 |
|||
move 1 from 2 to 4 |
|||
move 4 from 1 to 2 |
|||
move 2 from 6 to 2 |
|||
move 28 from 1 to 3 |
|||
move 1 from 9 to 7 |
|||
move 1 from 8 to 7 |
|||
move 1 from 5 to 4 |
|||
move 1 from 2 to 6 |
|||
move 1 from 3 to 1 |
|||
move 3 from 2 to 5 |
|||
move 1 from 6 to 3 |
|||
move 4 from 4 to 7 |
|||
move 5 from 5 to 2 |
|||
move 1 from 5 to 6 |
|||
move 6 from 1 to 3 |
|||
move 1 from 6 to 2 |
|||
move 26 from 3 to 6 |
|||
move 2 from 7 to 9 |
|||
move 4 from 7 to 3 |
|||
move 19 from 6 to 3 |
|||
move 6 from 2 to 4 |
|||
move 5 from 3 to 2 |
|||
move 1 from 9 to 7 |
|||
move 26 from 3 to 8 |
|||
move 6 from 4 to 3 |
|||
move 1 from 3 to 8 |
|||
move 1 from 6 to 7 |
|||
move 6 from 3 to 6 |
|||
move 6 from 6 to 4 |
|||
move 1 from 9 to 2 |
|||
move 2 from 4 to 9 |
|||
move 22 from 8 to 2 |
|||
move 2 from 6 to 5 |
|||
move 1 from 9 to 1 |
|||
move 1 from 6 to 5 |
|||
move 1 from 7 to 5 |
|||
move 3 from 6 to 7 |
|||
move 2 from 6 to 1 |
|||
move 1 from 1 to 5 |
|||
move 3 from 5 to 9 |
|||
move 4 from 8 to 4 |
|||
move 2 from 1 to 4 |
|||
move 18 from 2 to 1 |
|||
move 2 from 7 to 8 |
|||
move 3 from 9 to 5 |
|||
move 8 from 1 to 9 |
|||
move 5 from 9 to 3 |
|||
move 1 from 9 to 8 |
|||
move 2 from 9 to 4 |
|||
move 2 from 7 to 8 |
|||
move 5 from 5 to 7 |
|||
move 1 from 9 to 3 |
|||
move 4 from 8 to 4 |
|||
move 1 from 7 to 8 |
|||
move 4 from 4 to 3 |
|||
move 2 from 8 to 3 |
|||
move 1 from 8 to 9 |
|||
move 2 from 1 to 8 |
|||
move 3 from 4 to 5 |
|||
move 1 from 8 to 4 |
|||
move 1 from 9 to 3 |
|||
move 1 from 8 to 5 |
|||
move 8 from 1 to 8 |
|||
move 11 from 2 to 9 |
|||
move 12 from 3 to 5 |
|||
move 1 from 3 to 9 |
|||
move 1 from 8 to 5 |
|||
move 11 from 9 to 3 |
|||
move 4 from 5 to 9 |
|||
move 3 from 8 to 7 |
|||
move 3 from 7 to 8 |
|||
move 1 from 5 to 8 |
|||
move 7 from 4 to 3 |
|||
move 1 from 4 to 5 |
|||
move 1 from 2 to 8 |
|||
move 3 from 7 to 6 |
|||
move 3 from 4 to 8 |
|||
move 1 from 7 to 9 |
|||
move 2 from 4 to 7 |
|||
move 5 from 8 to 1 |
|||
move 3 from 6 to 5 |
|||
move 2 from 4 to 2 |
|||
move 1 from 9 to 4 |
|||
move 1 from 8 to 6 |
|||
move 1 from 2 to 9 |
|||
move 1 from 8 to 5 |
|||
move 3 from 8 to 4 |
|||
move 3 from 4 to 2 |
|||
move 4 from 3 to 9 |
|||
move 17 from 5 to 9 |
|||
move 9 from 9 to 6 |
|||
move 1 from 9 to 3 |
|||
move 5 from 6 to 3 |
|||
move 3 from 6 to 3 |
|||
move 8 from 9 to 5 |
|||
move 2 from 8 to 5 |
|||
move 1 from 4 to 8 |
|||
move 1 from 5 to 3 |
|||
move 1 from 8 to 5 |
|||
move 3 from 2 to 6 |
|||
move 3 from 1 to 4 |
|||
move 7 from 5 to 1 |
|||
move 1 from 2 to 6 |
|||
move 13 from 3 to 6 |
|||
move 2 from 7 to 8 |
|||
move 13 from 6 to 5 |
|||
move 3 from 5 to 7 |
|||
move 6 from 5 to 6 |
|||
move 1 from 7 to 6 |
|||
move 2 from 7 to 3 |
|||
move 1 from 6 to 8 |
|||
move 13 from 3 to 5 |
|||
move 9 from 5 to 9 |
|||
move 7 from 5 to 7 |
|||
move 17 from 9 to 2 |
|||
move 3 from 4 to 7 |
|||
move 9 from 2 to 9 |
|||
move 10 from 9 to 3 |
|||
move 8 from 7 to 8 |
|||
move 2 from 5 to 3 |
|||
move 4 from 2 to 6 |
|||
move 11 from 3 to 9 |
|||
move 9 from 6 to 5 |
|||
move 5 from 9 to 8 |
|||
move 1 from 3 to 1 |
|||
move 3 from 9 to 1 |
|||
move 2 from 5 to 2 |
|||
move 1 from 7 to 9 |
|||
move 2 from 9 to 4 |
|||
move 2 from 9 to 8 |
|||
move 13 from 1 to 8 |
|||
move 3 from 8 to 5 |
|||
move 27 from 8 to 1 |
|||
move 10 from 5 to 9 |
|||
move 1 from 7 to 2 |
|||
move 2 from 4 to 3 |
|||
move 10 from 9 to 6 |
|||
move 1 from 8 to 7 |
|||
move 15 from 1 to 9 |
|||
move 13 from 9 to 5 |
|||
move 15 from 5 to 7 |
|||
move 5 from 1 to 3 |
|||
move 8 from 7 to 1 |
|||
move 7 from 7 to 1 |
|||
move 16 from 1 to 8 |
|||
move 4 from 3 to 9 |
|||
move 4 from 1 to 7 |
|||
move 4 from 9 to 6 |
|||
move 5 from 2 to 7 |
|||
move 15 from 8 to 6 |
|||
move 1 from 9 to 1 |
|||
move 3 from 3 to 4 |
|||
move 1 from 9 to 7 |
|||
move 1 from 2 to 7 |
|||
move 1 from 2 to 7 |
|||
move 1 from 8 to 1 |
|||
move 3 from 4 to 8 |
|||
move 3 from 8 to 1 |
|||
move 8 from 6 to 8 |
|||
move 7 from 1 to 4 |
|||
move 11 from 6 to 8 |
|||
move 14 from 6 to 5 |
|||
move 13 from 8 to 7 |
|||
move 4 from 7 to 5 |
|||
move 15 from 7 to 4 |
|||
move 6 from 5 to 4 |
|||
move 2 from 5 to 9 |
|||
move 1 from 5 to 2 |
|||
move 3 from 8 to 5 |
|||
move 19 from 4 to 7 |
|||
move 10 from 5 to 8 |
|||
move 2 from 6 to 8 |
|||
move 1 from 4 to 8 |
|||
move 2 from 7 to 9 |
|||
move 9 from 7 to 4 |
|||
move 6 from 4 to 6 |
|||
move 11 from 4 to 8 |
|||
move 2 from 5 to 4 |
|||
move 5 from 6 to 4 |
|||
move 1 from 6 to 7 |
|||
move 3 from 9 to 5 |
|||
move 3 from 8 to 5 |
|||
move 3 from 7 to 6 |
|||
move 11 from 8 to 7 |
|||
move 1 from 9 to 5 |
|||
move 1 from 6 to 8 |
|||
move 1 from 2 to 1 |
|||
move 5 from 4 to 9 |
|||
move 2 from 4 to 1 |
|||
move 2 from 1 to 4 |
|||
move 1 from 1 to 9 |
|||
move 4 from 5 to 1 |
|||
move 1 from 4 to 6 |
|||
move 17 from 7 to 5 |
|||
move 9 from 8 to 7 |
|||
move 6 from 9 to 7 |
|||
move 3 from 1 to 9 |
|||
move 12 from 7 to 9 |
|||
move 12 from 9 to 5 |
|||
move 5 from 7 to 9 |
|||
move 17 from 5 to 3 |
|||
move 7 from 3 to 1 |
|||
move 5 from 1 to 5 |
|||
move 5 from 9 to 2 |
|||
move 4 from 3 to 5 |
|||
move 1 from 4 to 8 |
|||
move 5 from 2 to 1 |
|||
move 22 from 5 to 9 |
|||
move 3 from 7 to 6 |
|||
move 6 from 6 to 9 |
|||
move 2 from 5 to 4 |
|||
move 1 from 6 to 3 |
|||
move 2 from 4 to 1 |
|||
move 3 from 8 to 2 |
|||
move 1 from 3 to 4 |
|||
move 24 from 9 to 1 |
|||
move 4 from 3 to 9 |
|||
move 2 from 2 to 9 |
|||
move 2 from 3 to 1 |
|||
move 1 from 8 to 6 |
|||
move 1 from 6 to 9 |
|||
move 1 from 8 to 9 |
|||
move 2 from 7 to 4 |
|||
move 1 from 8 to 3 |
|||
move 1 from 4 to 7 |
|||
move 3 from 9 to 8 |
|||
move 1 from 2 to 1 |
|||
move 9 from 9 to 3 |
|||
move 1 from 8 to 7 |
|||
move 1 from 4 to 3 |
|||
move 2 from 9 to 7 |
|||
move 1 from 9 to 3 |
|||
move 2 from 8 to 4 |
|||
move 12 from 3 to 8 |
|||
move 2 from 1 to 7 |
|||
move 1 from 4 to 3 |
|||
move 30 from 1 to 5 |
|||
move 6 from 5 to 7 |
|||
move 12 from 7 to 2 |
|||
move 1 from 3 to 4 |
|||
move 2 from 1 to 3 |
|||
move 1 from 4 to 9 |
|||
move 10 from 5 to 7 |
|||
move 10 from 2 to 6 |
|||
move 8 from 8 to 3 |
|||
move 3 from 1 to 3 |
|||
move 5 from 6 to 3 |
|||
move 2 from 8 to 5 |
|||
move 1 from 9 to 2 |
|||
move 2 from 8 to 6 |
|||
move 4 from 7 to 2 |
|||
move 3 from 2 to 7 |
|||
move 2 from 7 to 5 |
|||
move 1 from 4 to 9 |
|||
move 11 from 3 to 1 |
|||
move 7 from 6 to 9 |
|||
move 3 from 2 to 3 |
|||
move 10 from 1 to 7 |
|||
move 14 from 7 to 5 |
|||
move 3 from 7 to 6 |
|||
move 5 from 9 to 7 |
|||
move 29 from 5 to 7 |
|||
move 6 from 3 to 9 |
|||
move 2 from 9 to 7 |
|||
move 15 from 7 to 5 |
|||
move 11 from 5 to 6 |
|||
move 5 from 9 to 5 |
|||
move 10 from 5 to 8 |
|||
move 1 from 2 to 4 |
|||
move 1 from 8 to 2 |
|||
move 2 from 4 to 3 |
|||
move 2 from 5 to 9 |
|||
move 8 from 8 to 9 |
|||
move 11 from 9 to 3 |
|||
move 1 from 1 to 8 |
|||
move 18 from 7 to 3 |
|||
move 1 from 9 to 3 |
|||
move 28 from 3 to 5 |
|||
move 12 from 6 to 7 |
|||
move 1 from 2 to 9 |
|||
move 15 from 7 to 2 |
|||
move 1 from 8 to 1 |
|||
move 10 from 2 to 9 |
|||
move 10 from 5 to 3 |
|||
move 2 from 2 to 3 |
|||
move 18 from 3 to 4 |
|||
move 6 from 9 to 4 |
|||
move 1 from 1 to 7 |
|||
move 1 from 6 to 4 |
|||
move 1 from 8 to 2 |
|||
move 1 from 9 to 4 |
|||
move 2 from 9 to 4 |
|||
move 19 from 4 to 3 |
|||
move 1 from 7 to 9 |
|||
move 1 from 9 to 7 |
|||
move 1 from 6 to 8 |
|||
move 3 from 2 to 8 |
|||
move 2 from 9 to 5 |
|||
move 15 from 3 to 1 |
|||
move 7 from 5 to 1 |
|||
move 3 from 4 to 9 |
|||
move 1 from 7 to 2 |
|||
move 3 from 3 to 1 |
|||
move 6 from 5 to 2 |
|||
move 3 from 3 to 9 |
|||
move 4 from 9 to 2 |
|||
move 5 from 5 to 3 |
|||
move 1 from 3 to 5 |
|||
move 3 from 5 to 7 |
|||
move 3 from 8 to 5 |
|||
move 1 from 7 to 5 |
|||
move 4 from 5 to 1 |
|||
move 4 from 4 to 2 |
|||
move 2 from 7 to 8 |
|||
move 12 from 1 to 6 |
|||
move 1 from 8 to 6 |
|||
move 6 from 2 to 3 |
|||
move 9 from 3 to 8 |
|||
move 1 from 3 to 4 |
|||
move 3 from 6 to 1 |
|||
move 2 from 9 to 2 |
|||
move 1 from 4 to 5 |
|||
move 2 from 8 to 3 |
|||
move 10 from 2 to 1 |
|||
move 2 from 4 to 7 |
|||
move 12 from 1 to 4 |
|||
move 1 from 5 to 1 |
|||
move 7 from 4 to 9 |
|||
move 2 from 3 to 2 |
|||
move 6 from 9 to 2 |
|||
move 1 from 9 to 1 |
|||
move 1 from 7 to 8 |
|||
move 5 from 6 to 7 |
|||
move 3 from 6 to 1 |
|||
move 6 from 2 to 3 |
|||
move 2 from 4 to 3 |
|||
move 1 from 6 to 8 |
|||
move 1 from 6 to 7 |
|||
move 8 from 3 to 9 |
|||
move 2 from 4 to 5 |
|||
move 3 from 2 to 4 |
|||
move 10 from 8 to 2 |
|||
move 22 from 1 to 9 |
|||
move 9 from 2 to 4 |
|||
move 1 from 1 to 3 |
|||
move 1 from 3 to 2 |
|||
move 3 from 2 to 4 |
|||
move 2 from 7 to 1 |
|||
move 14 from 4 to 2 |
|||
move 2 from 1 to 8 |
|||
move 2 from 4 to 5 |
|||
move 4 from 7 to 8 |
|||
move 24 from 9 to 6 |
|||
move 3 from 5 to 9 |
|||
move 1 from 9 to 8 |
|||
move 1 from 5 to 2 |
|||
move 1 from 6 to 7 |
|||
move 6 from 9 to 1 |
|||
move 1 from 7 to 3 |
|||
move 5 from 8 to 6 |
|||
move 9 from 6 to 3 |
|||
move 4 from 1 to 4 |
|||
move 2 from 1 to 2 |
|||
move 11 from 6 to 3 |
|||
move 13 from 3 to 2 |
|||
move 2 from 9 to 8 |
|||
move 8 from 3 to 8 |
|||
move 2 from 8 to 5 |
|||
move 1 from 7 to 5 |
|||
move 3 from 6 to 3 |
|||
move 11 from 8 to 5 |
|||
move 13 from 2 to 4 |
|||
move 10 from 5 to 2 |
|||
move 2 from 3 to 4 |
|||
move 2 from 5 to 7 |
|||
move 15 from 4 to 9 |
|||
move 2 from 7 to 4 |
|||
move 2 from 4 to 2 |
|||
move 2 from 4 to 9 |
|||
move 2 from 4 to 2 |
|||
move 1 from 3 to 8 |
|||
move 1 from 8 to 1 |
|||
move 1 from 1 to 2 |
|||
move 1 from 6 to 3 |
|||
move 7 from 2 to 4 |
|||
move 1 from 5 to 3 |
|||
move 7 from 9 to 1 |
|||
move 7 from 1 to 2 |
|||
move 4 from 6 to 9 |
|||
move 12 from 9 to 7 |
|||
move 6 from 7 to 5 |
|||
move 1 from 3 to 5 |
|||
move 7 from 4 to 7 |
|||
move 3 from 7 to 8 |
|||
move 3 from 8 to 6 |
|||
move 18 from 2 to 9 |
|||
move 7 from 2 to 3 |
|||
move 15 from 9 to 4 |
|||
move 3 from 3 to 9 |
|||
move 1 from 3 to 1 |
|||
move 3 from 5 to 4 |
|||
move 1 from 1 to 2 |
|||
move 1 from 9 to 2 |
|||
move 2 from 6 to 2 |
|||
move 5 from 7 to 6 |
|||
move 5 from 2 to 7 |
|||
move 3 from 3 to 4 |
|||
move 5 from 5 to 3 |
|||
move 6 from 7 to 4 |
|||
move 9 from 4 to 2 |
|||
move 18 from 4 to 9 |
|||
move 6 from 2 to 1 |
|||
move 1 from 1 to 9 |
|||
move 4 from 7 to 4 |
|||
move 7 from 2 to 4 |
|||
move 1 from 2 to 8 |
|||
move 1 from 4 to 2 |
|||
move 4 from 3 to 4 |
|||
move 16 from 9 to 5 |
|||
move 9 from 9 to 8 |
|||
move 1 from 9 to 7 |
|||
move 4 from 1 to 2 |
|||
move 2 from 5 to 4 |
|||
move 10 from 5 to 4 |
|||
move 4 from 2 to 1 |
|||
move 5 from 1 to 2 |
|||
move 1 from 8 to 5 |
|||
move 1 from 6 to 5 |
|||
move 4 from 8 to 5 |
|||
move 2 from 6 to 9 |
|||
move 3 from 6 to 2 |
|||
move 2 from 9 to 1 |
|||
move 1 from 7 to 6 |
|||
move 1 from 3 to 8 |
|||
move 9 from 5 to 9 |
|||
move 4 from 8 to 1 |
|||
move 2 from 8 to 2 |
|||
move 1 from 5 to 7 |
|||
move 9 from 9 to 8 |
|||
move 1 from 7 to 5 |
|||
move 9 from 8 to 2 |
|||
move 6 from 1 to 6 |
|||
move 6 from 2 to 6 |
|||
move 10 from 2 to 5 |
|||
move 5 from 2 to 1 |
|||
move 1 from 3 to 5 |
|||
move 8 from 5 to 4 |
|||
move 5 from 1 to 3 |
|||
move 10 from 6 to 8 |
|||
move 3 from 6 to 9 |
|||
move 4 from 3 to 1 |
|||
move 5 from 8 to 2 |
|||
move 4 from 5 to 9 |
|||
move 1 from 3 to 7 |
|||
move 1 from 7 to 3 |
|||
move 1 from 8 to 6 |
|||
move 1 from 6 to 1 |
|||
move 15 from 4 to 8 |
|||
move 5 from 9 to 2 |
|||
move 1 from 9 to 1 |
|||
move 1 from 1 to 3 |
|||
move 6 from 4 to 8 |
|||
move 12 from 8 to 7 |
|||
move 1 from 3 to 5 |
|||
move 3 from 1 to 9 |
|||
move 13 from 4 to 9 |
|||
move 5 from 7 to 2 |
|||
move 1 from 5 to 4 |
|||
move 8 from 9 to 5 |
|||
move 6 from 2 to 5 |
|||
move 2 from 5 to 6 |
@ -0,0 +1,2 @@ |
|||
VGBBJCRMN |
|||
LBBVJBRMH |
Loading…
Reference in new issue