| 23191 | 2026-01-16 16:31:56 | Zsomi | Városnézés | cpp17 | Accepted 80/80 | 177ms | 98612 KiB |
#include <iostream>
#include <vector>
#include <unordered_set>
using namespace std;
vector<vector<int>> b, odaut;
vector<int> a, megtekintlat;
vector<bool> voltmarott;
bool ellehet_e = false;
int n;
int gbj(int start)
{
if (start == n)
{
ellehet_e = true;
odaut[start].push_back(start);
return a[n];
}
else if (!b[start].size())
return -1;
int max = -1, maxi;
voltmarott[start] = true;
for (int i = 0; i < b[start].size(); i++)
{
if (voltmarott[b[start][i]])
{
if (megtekintlat[b[start][i]] > max)
{
max = megtekintlat[b[start][i]];
maxi = i;
}
}
else
{
int x = gbj(b[start][i]);
if (x > max)
{
max = x;
maxi = i;
}
}
}
if (max > 0)
{
odaut[start].push_back(start);
for (int i = 0; i < odaut[b[start][maxi]].size(); i++)
{
odaut[start].push_back(odaut[b[start][maxi]][i]);
}
}
else if (max == -1)
return -1;
megtekintlat[start] = max + a[start];
return max + a[start];
}
int main()
{
int m;
cin >> n >> m;
a.resize(n + 1);
for (int i = 1; i < n + 1; i++)
cin >> a[i];
b.resize(n + 1, vector<int>());
megtekintlat.resize(n + 1, -1);
voltmarott.resize(n + 1, false);
odaut.resize(n + 1);
for (int i = 1; i < m + 1; i++)
{
int temp1, temp2;
cin >> temp1 >> temp2;
b[temp1].push_back(temp2);
}
int x = gbj(1);
//cout << x;
//if (ellehet_e)
//{
cout << x;
cout << "\n";
if (x != -1)
{
unordered_set<int> h = unordered_set<int>();
for (auto a : odaut[1])
{
if (h.count(a) == 0)
{
cout << a << " ";
h.insert(a);
}
}
cout << "\n";
}
//}
//else
// cout << -1 << "\n";
}| Subtask | Sum | Test | Verdict | Time | Memory | ||
|---|---|---|---|---|---|---|---|
| subtask1 | 0/0 | ||||||
| 1 | Accepted | 1ms | 316 KiB | ||||
| subtask2 | 20/20 | ||||||
| 2 | Accepted | 1ms | 316 KiB | ||||
| 3 | Accepted | 1ms | 316 KiB | ||||
| 4 | Accepted | 1ms | 500 KiB | ||||
| 5 | Accepted | 4ms | 564 KiB | ||||
| 6 | Accepted | 3ms | 560 KiB | ||||
| 7 | Accepted | 8ms | 964 KiB | ||||
| 8 | Accepted | 8ms | 820 KiB | ||||
| 9 | Accepted | 1ms | 316 KiB | ||||
| 10 | Accepted | 74ms | 37376 KiB | ||||
| 11 | Accepted | 1ms | 316 KiB | ||||
| 12 | Accepted | 1ms | 316 KiB | ||||
| subtask3 | 25/25 | ||||||
| 13 | Accepted | 1ms | 756 KiB | ||||
| 14 | Accepted | 1ms | 500 KiB | ||||
| 15 | Accepted | 1ms | 316 KiB | ||||
| 16 | Accepted | 1ms | 316 KiB | ||||
| 17 | Accepted | 1ms | 316 KiB | ||||
| 18 | Accepted | 1ms | 316 KiB | ||||
| 19 | Accepted | 1ms | 316 KiB | ||||
| 20 | Accepted | 1ms | 316 KiB | ||||
| 21 | Accepted | 1ms | 588 KiB | ||||
| 22 | Accepted | 4ms | 500 KiB | ||||
| 23 | Accepted | 2ms | 316 KiB | ||||
| 24 | Accepted | 4ms | 316 KiB | ||||
| 25 | Accepted | 2ms | 316 KiB | ||||
| 26 | Accepted | 3ms | 316 KiB | ||||
| 27 | Accepted | 4ms | 316 KiB | ||||
| 28 | Accepted | 27ms | 1264 KiB | ||||
| 29 | Accepted | 4ms | 564 KiB | ||||
| 30 | Accepted | 28ms | 1048 KiB | ||||
| 31 | Accepted | 16ms | 820 KiB | ||||
| 32 | Accepted | 34ms | 1076 KiB | ||||
| 33 | Accepted | 10ms | 1236 KiB | ||||
| subtask4 | 20/20 | ||||||
| 34 | Accepted | 1ms | 316 KiB | ||||
| 35 | Accepted | 1ms | 316 KiB | ||||
| 36 | Accepted | 1ms | 316 KiB | ||||
| 37 | Accepted | 1ms | 316 KiB | ||||
| 38 | Accepted | 1ms | 316 KiB | ||||
| 39 | Accepted | 1ms | 348 KiB | ||||
| 40 | Accepted | 1ms | 316 KiB | ||||
| 41 | Accepted | 1ms | 316 KiB | ||||
| 42 | Accepted | 2ms | 316 KiB | ||||
| 43 | Accepted | 2ms | 316 KiB | ||||
| 44 | Accepted | 2ms | 584 KiB | ||||
| 45 | Accepted | 2ms | 324 KiB | ||||
| 46 | Accepted | 1ms | 316 KiB | ||||
| 47 | Accepted | 1ms | 316 KiB | ||||
| 48 | Accepted | 1ms | 316 KiB | ||||
| 49 | Accepted | 1ms | 316 KiB | ||||
| 50 | Accepted | 1ms | 500 KiB | ||||
| 51 | Accepted | 1ms | 316 KiB | ||||
| 52 | Accepted | 1ms | 508 KiB | ||||
| 53 | Accepted | 1ms | 316 KiB | ||||
| 54 | Accepted | 1ms | 316 KiB | ||||
| 55 | Accepted | 1ms | 316 KiB | ||||
| 56 | Accepted | 1ms | 316 KiB | ||||
| 57 | Accepted | 1ms | 316 KiB | ||||
| 58 | Accepted | 1ms | 316 KiB | ||||
| 59 | Accepted | 1ms | 316 KiB | ||||
| 60 | Accepted | 1ms | 316 KiB | ||||
| 61 | Accepted | 1ms | 332 KiB | ||||
| 62 | Accepted | 1ms | 316 KiB | ||||
| 63 | Accepted | 1ms | 560 KiB | ||||
| 64 | Accepted | 1ms | 316 KiB | ||||
| 65 | Accepted | 1ms | 316 KiB | ||||
| 66 | Accepted | 1ms | 316 KiB | ||||
| subtask5 | 15/15 | ||||||
| 67 | Accepted | 1ms | 316 KiB | ||||
| 68 | Accepted | 1ms | 316 KiB | ||||
| 69 | Accepted | 1ms | 316 KiB | ||||
| 70 | Accepted | 1ms | 500 KiB | ||||
| 71 | Accepted | 4ms | 564 KiB | ||||
| 72 | Accepted | 3ms | 560 KiB | ||||
| 73 | Accepted | 8ms | 964 KiB | ||||
| 74 | Accepted | 8ms | 820 KiB | ||||
| 75 | Accepted | 1ms | 316 KiB | ||||
| 76 | Accepted | 74ms | 37376 KiB | ||||
| 77 | Accepted | 1ms | 316 KiB | ||||
| 78 | Accepted | 1ms | 316 KiB | ||||
| 79 | Accepted | 1ms | 756 KiB | ||||
| 80 | Accepted | 1ms | 500 KiB | ||||
| 81 | Accepted | 1ms | 316 KiB | ||||
| 82 | Accepted | 1ms | 316 KiB | ||||
| 83 | Accepted | 1ms | 316 KiB | ||||
| 84 | Accepted | 1ms | 316 KiB | ||||
| 85 | Accepted | 1ms | 316 KiB | ||||
| 86 | Accepted | 1ms | 316 KiB | ||||
| 87 | Accepted | 1ms | 588 KiB | ||||
| 88 | Accepted | 4ms | 500 KiB | ||||
| 89 | Accepted | 2ms | 316 KiB | ||||
| 90 | Accepted | 4ms | 316 KiB | ||||
| 91 | Accepted | 2ms | 316 KiB | ||||
| 92 | Accepted | 3ms | 316 KiB | ||||
| 93 | Accepted | 4ms | 316 KiB | ||||
| 94 | Accepted | 27ms | 1264 KiB | ||||
| 95 | Accepted | 4ms | 564 KiB | ||||
| 96 | Accepted | 28ms | 1048 KiB | ||||
| 97 | Accepted | 16ms | 820 KiB | ||||
| 98 | Accepted | 34ms | 1076 KiB | ||||
| 99 | Accepted | 10ms | 1236 KiB | ||||
| 100 | Accepted | 1ms | 316 KiB | ||||
| 101 | Accepted | 1ms | 316 KiB | ||||
| 102 | Accepted | 1ms | 316 KiB | ||||
| 103 | Accepted | 1ms | 316 KiB | ||||
| 104 | Accepted | 1ms | 348 KiB | ||||
| 105 | Accepted | 1ms | 316 KiB | ||||
| 106 | Accepted | 1ms | 316 KiB | ||||
| 107 | Accepted | 2ms | 316 KiB | ||||
| 108 | Accepted | 2ms | 316 KiB | ||||
| 109 | Accepted | 2ms | 584 KiB | ||||
| 110 | Accepted | 2ms | 324 KiB | ||||
| 111 | Accepted | 1ms | 316 KiB | ||||
| 112 | Accepted | 1ms | 316 KiB | ||||
| 113 | Accepted | 1ms | 316 KiB | ||||
| 114 | Accepted | 1ms | 316 KiB | ||||
| 115 | Accepted | 1ms | 500 KiB | ||||
| 116 | Accepted | 1ms | 316 KiB | ||||
| 117 | Accepted | 1ms | 508 KiB | ||||
| 118 | Accepted | 1ms | 316 KiB | ||||
| 119 | Accepted | 1ms | 316 KiB | ||||
| 120 | Accepted | 1ms | 316 KiB | ||||
| 121 | Accepted | 1ms | 316 KiB | ||||
| 122 | Accepted | 1ms | 316 KiB | ||||
| 123 | Accepted | 1ms | 316 KiB | ||||
| 124 | Accepted | 1ms | 316 KiB | ||||
| 125 | Accepted | 1ms | 316 KiB | ||||
| 126 | Accepted | 1ms | 332 KiB | ||||
| 127 | Accepted | 1ms | 316 KiB | ||||
| 128 | Accepted | 1ms | 560 KiB | ||||
| 129 | Accepted | 1ms | 316 KiB | ||||
| 130 | Accepted | 1ms | 316 KiB | ||||
| 131 | Accepted | 1ms | 316 KiB | ||||
| 132 | Accepted | 4ms | 316 KiB | ||||
| 133 | Accepted | 2ms | 316 KiB | ||||
| 134 | Accepted | 4ms | 316 KiB | ||||
| 135 | Accepted | 3ms | 316 KiB | ||||
| 136 | Accepted | 3ms | 544 KiB | ||||
| 137 | Accepted | 2ms | 316 KiB | ||||
| 138 | Accepted | 3ms | 316 KiB | ||||
| 139 | Accepted | 3ms | 316 KiB | ||||
| 140 | Accepted | 6ms | 564 KiB | ||||
| 141 | Accepted | 3ms | 564 KiB | ||||
| 142 | Accepted | 9ms | 932 KiB | ||||
| 143 | Accepted | 14ms | 3296 KiB | ||||
| 144 | Accepted | 12ms | 1104 KiB | ||||
| 145 | Accepted | 12ms | 3268 KiB | ||||
| 146 | Accepted | 21ms | 1844 KiB | ||||
| 147 | Accepted | 115ms | 58468 KiB | ||||
| 148 | Accepted | 177ms | 98612 KiB | ||||
| 149 | Accepted | 56ms | 32456 KiB | ||||