1
0
Fork 0
Advent2021/Day 10/Marcus/cpp/part2.cpp

62 lines
1.3 KiB
C++
Raw Normal View History

2021-12-10 05:31:06 +00:00
#include <iostream>
#include <stack>
#include <vector>
#include <algorithm>
using namespace std;
int main(int argc, char* argv[])
{
string str_in;
string openers = "([{<";
string closers = ")]}>";
vector<unsigned long long> all_results;
while(cin >> str_in)
{
stack<char> parser;
unsigned long long result = 0;
bool bl_is_corrupted = false;
for(unsigned int i = 0; i < str_in.size(); i++)
{
size_t found_pos;
if (openers.find(str_in[i])!=string::npos)
{
parser.push(str_in[i]);
}
else if ((found_pos=closers.find(str_in[i]))!=string::npos)
{
if (parser.top() != openers[found_pos])
{
bl_is_corrupted = true;
break;
}
else
{
parser.pop();
}
}
}
if (bl_is_corrupted)
{
continue;
}
while(!parser.empty())
{
result*=5;
result+=1+openers.find(parser.top());
parser.pop();
}
all_results.push_back(result);
}
sort(all_results.begin(),all_results.end());
cout << all_results[all_results.size()/2] << endl;
return 0;
}