Task: | HIIT Speedrun |
Sender: | Omochiikaeri~! |
Submission time: | 2019-05-25 14:53:01 +0300 |
Language: | C++ |
Status: | READY |
Result: | ACCEPTED |
test | verdict | time | |
---|---|---|---|
#1 | ACCEPTED | 0.02 s | details |
#2 | ACCEPTED | 0.01 s | details |
#3 | ACCEPTED | 0.02 s | details |
#4 | ACCEPTED | 0.01 s | details |
#5 | ACCEPTED | 0.06 s | details |
#6 | ACCEPTED | 0.03 s | details |
#7 | ACCEPTED | 0.03 s | details |
#8 | ACCEPTED | 0.02 s | details |
#9 | ACCEPTED | 0.02 s | details |
#10 | ACCEPTED | 0.02 s | details |
#11 | ACCEPTED | 0.02 s | details |
#12 | ACCEPTED | 0.02 s | details |
#13 | ACCEPTED | 0.07 s | details |
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 |