import sys
input = sys.stdin.readline
INF = int(1e9)
n = int(input())
m = int(input())
graph = [[INF] * (n + 1) for _ inrange(n + 1)]
for a inrange(1, n + 1):
for b inrange(1, n + 1):
if a == b:
graph[a][b] = 0for _ inrange(m):
a, b, c = map(int, input().split())
graph[a][b] = min(c, graph[a][b])
for k inrange(1, n + 1):
for a inrange(1, n + 1):
for b inrange(1, n + 1):
graph[a][b] = min(graph[a][b], graph[a][k] + graph[k][b])
for a inrange(1, n + 1):
for b inrange(1, n + 1):
if graph[a][b] == INF:
print(0, end=' ')
else:
print(graph[a][b], end=' ')
print()