3325 - Ohoo

From Bitnami MediaWiki

Cerinta

Porumbeii au pornit un război crâncen împotriva ciorilor, dar ele au construit garduri defensive pe toate rutele pe care le-ar putea folosi armata porumbeilor pentru a le ataca cetatea. Pentru a ajunge la cetatea ciorilor armata trebuie sa treacă de gardurile construite de ciori.

Pentru că porumbeii obosesc din cauza zborului ei trebuie sa se odihneasca pe statui, astfel armata poate merge doar pe drumurile cunoscute dintre două statui. Există n statui, iar armata se află inițial pe statuia cu numărul 1, iar cetatea ciorilor se va afla pe cea cu numărul n.

Armata porumbeilor deține un cioc bionic de putere K. Acesta poate sparge garduri cu rezistență mai mica sau egala cu K, armata putând astfel să treacă pe acel drum.

Generalul armatei porumbeilor vă cere să găsiți puterea minimă pe care o poate avea ciocul bionic pentru ca armata să poată ajunge la cetatea ciorilor

Date de intrare

Fișierul de intrare Ohoo.in va conține: Pe prima linie numărul natural n reprezentând numărul de statui și numărul natural m reprezentând numărul de drumuri existente între statui. Pe următoarele m linii se vor găsi câte 3 numere: x, y, r, cu semnificația că există un drum bidirecțional între statuile x și y blocat de un gard de rezistență r.

Date de iesire

Fișierul de ieșire Ohoo.out va conține un singur număr natural K, reprezentând puterea minimă pe care o poate avea ciocul bionic astfel încât armata să poată ajunge la cetatea ciorilor.

Restrictii si precizari:

2 ≤ n ≤ 100.000

1 ≤ m ≤ 250.000

Rezistențele gardurilor sunt numere naturale nenule și nu depășesc 1.000.000

Între două statui pot exista mai multe drumuri cu garduri de rezistențe diferite

Întotdeauna există soluție

Pentru 60% din teste n ≤ 1000 și K ≤ 1000

Se acordă 10 puncte pentru exemplu

Atenție la numele fișirelor de intrare și de ieșire!

Exemplu

Ohoo.in

5 6

1 2 3

1 4 1

2 3 2

3 5 3

4 5 4

3 4 4

Ohoo.out

3

Explicatie

Alegem drumul 1-2-3-5 folosind o putere maximă de 3.

Rezolvare

<syntaxhighlight lang="python3"> from collections import defaultdict

def dfs(node, d):

   global t
   if node == n:
       t = True
   else:
       vis[node] = True
       for i, c in graph[node]:
           if not t and c <= d and not vis[i]:
               dfs(i, d)

def main():

   global n, m, vis, t, graph
   with open("Ohoo.in", "r") as fin:
       n, m = map(int, fin.readline().split())
       graph = defaultdict(list)
       mz = 0
       for _ in range(m):
           x, y, c = map(int, fin.readline().split())
           graph[x].append((y, c))
           graph[y].append((x, c))
           mz = max(mz, c)
   st, dr, sol = 1, mz, mz
   while st <= dr:
       mij = (st + dr) // 2
       vis = [False] * (n + 1)
       t = False
       dfs(1, mij)
       if t:
           sol = mij
           dr = mij - 1
       else:
           st = mij + 1
   with open("Ohoo.out", "w") as fout:
       fout.write(str(sol) + '\n')

if __name__ == "__main__":

   main()

</syntaxhighlight>