всем добрый вечер вот изучил новый алгоритм на графы и хотел порешать задачи для закрепления но вот встал на одной из задач Дейкстры который находится на сайте e-olimp.ru problems 1389 написал код но проходит только 70% буду благодарен за помощь
№ | Пользователь | Рейтинг |
---|---|---|
1 | tourist | 4009 |
2 | jiangly | 3823 |
3 | Benq | 3738 |
4 | Radewoosh | 3633 |
5 | jqdai0815 | 3620 |
6 | orzdevinwang | 3529 |
7 | ecnerwala | 3446 |
8 | Um_nik | 3396 |
9 | ksun48 | 3390 |
10 | gamegame | 3386 |
Страны | Города | Организации | Всё → |
№ | Пользователь | Вклад |
---|---|---|
1 | cry | 167 |
2 | Um_nik | 163 |
3 | maomao90 | 162 |
4 | atcoder_official | 161 |
5 | adamant | 159 |
6 | -is-this-fft- | 158 |
7 | awoo | 157 |
8 | TheScrasse | 154 |
9 | Dominater069 | 153 |
9 | nor | 153 |
всем добрый вечер вот изучил новый алгоритм на графы и хотел порешать задачи для закрепления но вот встал на одной из задач Дейкстры который находится на сайте e-olimp.ru problems 1389 написал код но проходит только 70% буду благодарен за помощь
Название |
---|
Во-первых, у тебя неправильно написана Дейкстра: нам нужно каждую итерацию доставать вершину с минимальным расстоянием до нее. Ты же вместо этого достаешь вершину с минимальным номером. Так как в сете ты хранишь пару (номер вершины, расстояние до нее), а пары сравниваются по первому параметру, а в случае равенства — по второму.
Однако даже с такой реализацией исправленное решение проходит все тесты. Видимо, потому что граф небольшой. К сожалению, я не могу оценить время работы такого алгоритма.
Во-вторых, когда ты производишь релаксацию, ты удаляешь неправильную пару:
q.erase(make_pair(to,y));
Мы обнаружили, что если пойти по такому-то ребру, мы попадем в вершину to быстрее. Так как минимальное расстояние до вершины to изменилось, нужно удалить старое расстояние и добавить новое. Т.е. было d[to], стало y, значит нужно удалить пару (d[to], to), добавить (y, to) и обновить d[to] = y.
В-третьих, у тебя различаются расстояния до вершин в сете и в массиве d, они должны быть одинаковыми.
В d[v] мы храним минимальное время, за которое можно добраться до вершины. Поэтому нужно проверить, а не будет ли быстрее добраться до вершины to этим маршрутом? Так как y — это время прибытия в вершину to, то код будет выглядить так: