CSES - HIIT Open 2019 - Results
Submission details
Task:HIIT Speedrun
Sender:Omochiikaeri~!
Submission time:2019-05-25 14:53:01 +0300
Language:C++
Status:READY
Result:ACCEPTED
Test results
testverdicttime
#1ACCEPTED0.02 sdetails
#2ACCEPTED0.01 sdetails
#3ACCEPTED0.02 sdetails
#4ACCEPTED0.01 sdetails
#5ACCEPTED0.06 sdetails
#6ACCEPTED0.03 sdetails
#7ACCEPTED0.03 sdetails
#8ACCEPTED0.02 sdetails
#9ACCEPTED0.02 sdetails
#10ACCEPTED0.02 sdetails
#11ACCEPTED0.02 sdetails
#12ACCEPTED0.02 sdetails
#13ACCEPTED0.07 sdetails

Compiler report

input/code.cpp: In function 'int main()':
input/code.cpp:53:31: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             for (int j = 0; j < connections[p].size(); j++) {
                             ~~^~~~~~~~~~~~~~~~~~~~~~~
input/code.cpp:70:27: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     for (int h_i = 0; h_i < hs.size(); h_i++) {
                       ~~~~^~~~~~~~~~~
input/code.cpp:72:33: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
         for (int i1_i = 0; i1_i < is.size(); i1_i++) {
                            ~~~~~^~~~~~~~~~~
input/code.cpp:74:42: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             for (int i2_i = i1_i+1; i2_i < is.size(); i2_i++) {
                                     ~~~~~^~~~~~~~~~~
input/code.cpp:76:39: warning: comparison between signed and unsigned integer expressions [-Wsign-compar...

Code

#include <iostream>
#include <queue>
#include <vector>
using namespace std;
vector<int> hs;
vector<int> is;
vector<int> ts;
vector<int> connections[100];
int distances[100][100] = {0};
unsigned min(unsigned a, unsigned b) {
return a < b ? a : b;
}
int main() {
int n, m;
cin >> n >> m;
for (int i = 0; i < n; i++) {
char c;
cin >> c;
if (c == 'H'){
hs.push_back(i);
}
if (c == 'I'){
is.push_back(i);
}
if (c == 'T'){
ts.push_back(i);
}
}
for (int i = 0; i < m; i++) {
int a, b;
cin >> a >> b;
connections[a-1].push_back(b-1);
connections[b-1].push_back(a-1);
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
distances[i][j] = -1;
}
distances[i][i] = 0;
queue<int> q;
q.push(i);
while (q.size()) {
int p = q.front();
q.pop();
for (int j = 0; j < connections[p].size(); j++) {
int neigh = connections[p][j];
if (distances[i][neigh] == -1) {
distances[i][neigh] = distances[i][p] + 1;
q.push(neigh);
}
}
}
}
unsigned shortest = -1;
#define TRYM(a, b, c, d) \
if (distances[0][a] != -1 && distances[a][b] != -1 && distances[b][c] != -1 && distances[c][d] != -1 && distances[d][n-1] != -1) { \
shortest = min(shortest, distances[0][a] + distances[a][b] + distances[b][c] + distances[c][d] + distances[d][n-1]); \
}
for (int h_i = 0; h_i < hs.size(); h_i++) {
int h = hs[h_i];
for (int i1_i = 0; i1_i < is.size(); i1_i++) {
int i1 = is[i1_i];
for (int i2_i = i1_i+1; i2_i < is.size(); i2_i++) {
int i2 = is[i2_i];
for (int t_i = 0; t_i < ts.size(); t_i++) {
int t = ts[t_i];
TRYM(h, i1, i2, t);
TRYM(h, i1, t, i2);
TRYM(h, i2, i1, t);
TRYM(h, i2, t, i1);
TRYM(h, t, i1, i2);
TRYM(h, t, i2, i1);
TRYM(i1, h, i2, t);
TRYM(i1, h, t, i2);
TRYM(i1, i2, h, t);
TRYM(i1, i2, t, h);
TRYM(i1, t, h, i2);
TRYM(i1, t, i2, h);
TRYM(i2, i1, h, t);
TRYM(i2, i1, t, h);
TRYM(i2, h, i1, t);
TRYM(i2, h, t, i1);
TRYM(i2, t, i1, h);
TRYM(i2, t, h, i1);
TRYM(t, i1, i2, h);
TRYM(t, i1, h, i2);
TRYM(t, i2, i1, h);
TRYM(t, i2, h, i1);
TRYM(t, h, i1, i2);
TRYM(t, h, i2, i1);
}
}
}
}
if (shortest == (unsigned) -1) {
cout << "IMPOSSIBLE" << endl;
} else {
cout << shortest << endl;
}
}

Test details

Test 1

Verdict: ACCEPTED

input
4 0
HIIT

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 2

Verdict: ACCEPTED

input
4 3
HIIT
1 2
2 3
3 4

correct output
3

user output
3

Test 3

Verdict: ACCEPTED

input
4 3
HIIT
4 3
3 2
2 1

correct output
3

user output
3

Test 4

Verdict: ACCEPTED

input
6 5
XHIITX
1 2
1 3
1 4
...

correct output
9

user output
9

Test 5

Verdict: ACCEPTED

input
100 5000
TIIIIIIITHHHTHHHIHIIHIHHHITHIH...

correct output
3

user output
3

Test 6

Verdict: ACCEPTED

input
100 99
HIIIIIIIIIIIIIIIIIIIIIIIIIIIII...

correct output
99

user output
99

Test 7

Verdict: ACCEPTED

input
10 10
AAAHIITAAA
1 2
2 3
3 4
...

correct output
9

user output
9

Test 8

Verdict: ACCEPTED

input
9 9
HIIIIIIIT
1 2
2 3
3 4
...

correct output
4

user output
4

Test 9

Verdict: ACCEPTED

input
9 9
HIIIIAAAT
1 2
2 3
3 4
...

correct output
5

user output
5

Test 10

Verdict: ACCEPTED

input
100 99
HIIIIIIIIIIIIIIIIIIIIIIIIIIIII...

correct output
197

user output
197

Test 11

Verdict: ACCEPTED

input
8 8
HIITHIIT
1 2
2 3
3 4
...

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 12

Verdict: ACCEPTED

input
6 5
HIIITI
1 2
2 3
3 4
...

correct output
IMPOSSIBLE

user output
IMPOSSIBLE

Test 13

Verdict: ACCEPTED

input
100 99
HHHHHHHHHHHHHHHHHHHHHHHHHIIIII...

correct output
99

user output
99