/*
Author : Chandan Agrawal
College : Poornima College of Engg. jaipur, Raj
Mail : chandanagrawal23@gmail.com
" when you are not practicing someone else is ,
and the day u meet them u will lose "
*/
#include<bits/stdc++.h>
#include<stdio.h>
using namespace std;
#define fastio ios_base::sync_with_stdio(false);cin.tie(0);cout.tie(0);
#define MAX 200050
#define ll long long
#define ld long double
#define lli long long int
#define pb push_back
#define INF 1000000000000
#define mod 1000000007
// trignometric function always give value in Radians only
#define PI acos(-1) //3.1415926535897932384626433832795028
#define dsin(degree) sin(degree*(PI/180.0))
#define dcos(degree) cos(degree*(PI/180.0))
#define dtan(degree) tan(degree*(PI/180.0))
#define rsin(radian) sin(radian)
#define rcos(radian) cos(radian)
#define rtan(radian) tan(radian)
#define mem0(a) memset(a,0,sizeof(a))
#define mem1(a) memset(a,-1,sizeof(a))
#define memf(a) memset(a,false,sizeof(a))
#define loop(i,n) for (lli i = 0; i < n; i++)
#define FOR(i,a,b) for (lli i = a; i < b; i++)
#define all(v) v.begin(),v.end()
#define rall(v) v.rbegin(),v.rend()
#define sz(x) int(x.size())
#define F first
#define S second
#define mii map<lli,lli>
#define mci map<char,lli>
#define vi vector<lli>
#define vbool vector<bool>
#define seti set<lli>
#define pii pair<lli,lli>
#define pcc pair<char,char>
#define gcd(a,b) __gcd((a),(b))
#define lcm(a,b) (a/gcd(a,b))*b
#define abs(x) ((x < 0)?-(x):x)
#define endl '\n'
template <typename T>
void print(T x){cout<<x<<endl;}
template <typename T1, typename T2>
void print2(T1 x,T2 y){cout<<x<<" "<<y<<endl;}
template <typename T1, typename T2,typename T3>
void print3(T1 x, T2 y,T3 z){cout<<x<<" "<<y<<" "<<z<<endl;}
#define scanarr(a,n) for(lli i=0;i<n;i++) cin>>a[i];
#define scanvec(a,n) for(lli i=0;i<n;i++){ lli x ; cin>>x; a.pb(x);}
#define printarr(a,n) for(lli i=0;i<n;i++) cout<<a[i]<<" "; cout<<endl;
#define printvec(vec) for(auto xt : vec) cout<<xt<<" "; cout<<"\n";
#define FD(N) fixed<<setprecision(N)
#define deb(x) cout<<#x<<" "<<x<<endl;
// chandan1,2
void chandan1(){int y=1;return;}
void chandan2(){
loop(i,10){
lli x=1;
}
return(chandan1());
}
//BELLMAN FORD
// check only negative cycle is there or not
void isNegCycle(vector<pii> adj[] , lli src , lli n)
{
vi dist(n+1,INF) , cnt(n+1,0);
vbool vis(n+1,false);
queue<lli> q;
q.push(src);
dist[src]=0;
vis[src]=1;
while(!q.empty())
{
lli u = q.front(); q.pop();
vis[u] = false;
for (auto edge : adj[u])
{
lli child = edge.S;
lli cost = edge.F;
if (dist[child] > dist[u] + cost)
{
dist[child] = dist[u] + cost;
if (!vis[child])
{
q.push(child);
vis[child] = true;
cnt[child]++;
if (cnt[child] > n)
{
break;
//return true; //negative cycle
}
}
}
}
}
// return false;
for(lli i=1;i<=n;i++)
{
if(dist[i]==INF)
cout<<30000<<" ";
else
cout<<dist[i]<<" ";
}
}
int main(){
fastio
lli t=1;
//cin>>t;
chandan2();
while(t--) {
lli n;
cin>>n;
// vector of pair <cost , node>
vector<pii> adj[n+1];
lli m;
cin>>m;
lli dp[n][n];
loop(i,n)
{
loop(j,n)
{
if(i==j)
dp[i][j]=0;
else
dp[i][j] = INF;
}
}
loop(i,m)
{
lli x,y,cost;
cin>>x>>y>>cost;
--x;
y--;
dp[x][x]=0;
dp[y][y]=0;
dp[x][y]=(cost);
adj[x+1].pb({cost , y+1});
}
loop(k,n)
{
loop(i,n)
{
loop(j,n)
{
if(dp[i][k]!=INF and dp[k][j]!=INF )
dp[i][j] = min(dp[i][j] , dp[i][k]+dp[k][j]);
}
}
}
cout<<"By floyd warshall\n";
loop(i,n)
{
if(dp[0][i]>30000)
cout<<30000<<" ";
else
cout<<dp[0][i]<<" ";
}
cout<<endl;
cout<<"By bellman ford\n";
isNegCycle(adj,1,n);
}
return 0;
}
LyoKQXV0aG9yIDogQ2hhbmRhbiBBZ3Jhd2FsCkNvbGxlZ2UgOiBQb29ybmltYSBDb2xsZWdlIG9mIEVuZ2cuIGphaXB1ciwgUmFqCk1haWwgOiBjaGFuZGFuYWdyYXdhbDIzQGdtYWlsLmNvbQoKCiIgd2hlbiB5b3UgYXJlIG5vdCBwcmFjdGljaW5nIHNvbWVvbmUgZWxzZSBpcyAsCiBhbmQgdGhlIGRheSB1IG1lZXQgdGhlbSB1IHdpbGwgbG9zZSAiCgoqLwojaW5jbHVkZTxiaXRzL3N0ZGMrKy5oPgojaW5jbHVkZTxzdGRpby5oPgp1c2luZyBuYW1lc3BhY2Ugc3RkOwoKI2RlZmluZSBmYXN0aW8gaW9zX2Jhc2U6OnN5bmNfd2l0aF9zdGRpbyhmYWxzZSk7Y2luLnRpZSgwKTtjb3V0LnRpZSgwKTsKI2RlZmluZSBNQVggMjAwMDUwCgojZGVmaW5lIGxsIGxvbmcgbG9uZwojZGVmaW5lIGxkIGxvbmcgZG91YmxlCiNkZWZpbmUgbGxpIGxvbmcgbG9uZyBpbnQKCiNkZWZpbmUgcGIgcHVzaF9iYWNrCiNkZWZpbmUgSU5GIDEwMDAwMDAwMDAwMDAKI2RlZmluZSBtb2QgMTAwMDAwMDAwNwoKLy8gdHJpZ25vbWV0cmljIGZ1bmN0aW9uIGFsd2F5cyBnaXZlIHZhbHVlIGluIFJhZGlhbnMgb25seQojZGVmaW5lIFBJIGFjb3MoLTEpIC8vMy4xNDE1OTI2NTM1ODk3OTMyMzg0NjI2NDMzODMyNzk1MDI4CiNkZWZpbmUgZHNpbihkZWdyZWUpIHNpbihkZWdyZWUqKFBJLzE4MC4wKSkKI2RlZmluZSBkY29zKGRlZ3JlZSkgY29zKGRlZ3JlZSooUEkvMTgwLjApKQojZGVmaW5lIGR0YW4oZGVncmVlKSB0YW4oZGVncmVlKihQSS8xODAuMCkpCgojZGVmaW5lIHJzaW4ocmFkaWFuKSBzaW4ocmFkaWFuKQojZGVmaW5lIHJjb3MocmFkaWFuKSBjb3MocmFkaWFuKQojZGVmaW5lIHJ0YW4ocmFkaWFuKSB0YW4ocmFkaWFuKQoKI2RlZmluZSBtZW0wKGEpIG1lbXNldChhLDAsc2l6ZW9mKGEpKQojZGVmaW5lIG1lbTEoYSkgbWVtc2V0KGEsLTEsc2l6ZW9mKGEpKQojZGVmaW5lIG1lbWYoYSkgbWVtc2V0KGEsZmFsc2Usc2l6ZW9mKGEpKQoKI2RlZmluZSBsb29wKGksbikgIGZvciAobGxpIGkgPSAwOyBpIDwgbjsgaSsrKQojZGVmaW5lIEZPUihpLGEsYikgZm9yIChsbGkgaSA9IGE7IGkgPCBiOyBpKyspCgojZGVmaW5lIGFsbCh2KSB2LmJlZ2luKCksdi5lbmQoKQojZGVmaW5lIHJhbGwodikgdi5yYmVnaW4oKSx2LnJlbmQoKQojZGVmaW5lIHN6KHgpIGludCh4LnNpemUoKSkKI2RlZmluZSBGIGZpcnN0CiNkZWZpbmUgUyBzZWNvbmQKCiNkZWZpbmUgbWlpIG1hcDxsbGksbGxpPgojZGVmaW5lIG1jaSBtYXA8Y2hhcixsbGk+CiNkZWZpbmUgdmkgdmVjdG9yPGxsaT4KI2RlZmluZSB2Ym9vbCB2ZWN0b3I8Ym9vbD4KI2RlZmluZSBzZXRpIHNldDxsbGk+CiNkZWZpbmUgcGlpIHBhaXI8bGxpLGxsaT4KI2RlZmluZSBwY2MgcGFpcjxjaGFyLGNoYXI+CgojZGVmaW5lIGdjZChhLGIpIF9fZ2NkKChhKSwoYikpCiNkZWZpbmUgbGNtKGEsYikgKGEvZ2NkKGEsYikpKmIKI2RlZmluZSBhYnMoeCkgKCh4IDwgMCk/LSh4KTp4KQoKI2RlZmluZSBlbmRsICdcbicKCnRlbXBsYXRlIDx0eXBlbmFtZSBUPgp2b2lkIHByaW50KFQgeCl7Y291dDw8eDw8ZW5kbDt9CnRlbXBsYXRlIDx0eXBlbmFtZSBUMSwgdHlwZW5hbWUgVDI+CnZvaWQgcHJpbnQyKFQxIHgsVDIgeSl7Y291dDw8eDw8IiAiPDx5PDxlbmRsO30KdGVtcGxhdGUgPHR5cGVuYW1lIFQxLCB0eXBlbmFtZSBUMix0eXBlbmFtZSBUMz4Kdm9pZCBwcmludDMoVDEgeCwgVDIgeSxUMyB6KXtjb3V0PDx4PDwiICI8PHk8PCIgIjw8ejw8ZW5kbDt9CgojZGVmaW5lIHNjYW5hcnIoYSxuKSBmb3IobGxpIGk9MDtpPG47aSsrKSAgICBjaW4+PmFbaV07CiNkZWZpbmUgc2NhbnZlYyhhLG4pIGZvcihsbGkgaT0wO2k8bjtpKyspeyBsbGkgeCA7IGNpbj4+eDsgYS5wYih4KTt9CgojZGVmaW5lIHByaW50YXJyKGEsbikgZm9yKGxsaSBpPTA7aTxuO2krKykgICBjb3V0PDxhW2ldPDwiICI7IGNvdXQ8PGVuZGw7CiNkZWZpbmUgcHJpbnR2ZWModmVjKSBmb3IoYXV0byB4dCA6IHZlYykgY291dDw8eHQ8PCIgIjsgICAgY291dDw8IlxuIjsKCiNkZWZpbmUgRkQoTikgZml4ZWQ8PHNldHByZWNpc2lvbihOKQoKI2RlZmluZSBkZWIoeCkgY291dDw8I3g8PCIgIjw8eDw8ZW5kbDsKCi8vIGNoYW5kYW4xLDIKdm9pZCBjaGFuZGFuMSgpe2ludCB5PTE7cmV0dXJuO30Kdm9pZCBjaGFuZGFuMigpewogICAgICAgIGxvb3AoaSwxMCl7CiAgICAgICAgbGxpIHg9MTsKICAgIH0KICAgIHJldHVybihjaGFuZGFuMSgpKTsKfQoKLy9CRUxMTUFOIEZPUkQKLy8gY2hlY2sgb25seSBuZWdhdGl2ZSBjeWNsZSBpcyB0aGVyZSBvciBub3QKdm9pZCBpc05lZ0N5Y2xlKHZlY3RvcjxwaWk+IGFkaltdICwgbGxpIHNyYyAsIGxsaSBuKQp7CiAgICAKICAgIHZpIGRpc3QobisxLElORikgLCBjbnQobisxLDApOwogICAgCiAgICB2Ym9vbCB2aXMobisxLGZhbHNlKTsKICAgIAogICAgcXVldWU8bGxpPiBxOwogICAgCiAgICBxLnB1c2goc3JjKTsKICAgIGRpc3Rbc3JjXT0wOwogICAgdmlzW3NyY109MTsKICAgIAogICAgd2hpbGUoIXEuZW1wdHkoKSkKICAgIHsKICAgICAgICBsbGkgdSA9IHEuZnJvbnQoKTsgcS5wb3AoKTsKICAgICAgICAKICAgICAgICB2aXNbdV0gPSBmYWxzZTsKICAgICAgICAKICAgICAgICBmb3IgKGF1dG8gZWRnZSA6IGFkalt1XSkKICAgICAgICB7CiAgICAgICAgICAgIGxsaSBjaGlsZCA9IGVkZ2UuUzsKICAgICAgICAgICAgbGxpIGNvc3QgID0gZWRnZS5GOwoKICAgICAgICAgICAgaWYgKGRpc3RbY2hpbGRdID4gZGlzdFt1XSArIGNvc3QpIAogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgIGRpc3RbY2hpbGRdID0gZGlzdFt1XSArIGNvc3Q7CgogICAgICAgICAgICAgICAgaWYgKCF2aXNbY2hpbGRdKSAKICAgICAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgICAgICBxLnB1c2goY2hpbGQpOwogICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgIHZpc1tjaGlsZF0gPSB0cnVlOwogICAgICAgICAgICAgICAgICAgIAogICAgICAgICAgICAgICAgICAgIGNudFtjaGlsZF0rKzsKICAgICAgICAgICAgICAgICAgICAKICAgICAgICAgICAgICAgICAgICBpZiAoY250W2NoaWxkXSA+IG4pCiAgICAgICAgICAgICAgICAgICAgewogICAgICAgICAgICAgICAgICAgICAgICBicmVhazsKICAgICAgICAgICAgICAgICAgICAgICAvL3JldHVybiB0cnVlOyAvL25lZ2F0aXZlIGN5Y2xlCiAgICAgICAgICAgICAgICAgICAgfQogICAgICAgICAgICAgICAgfQogICAgICAgICAgICB9CiAgICAgICAgfQogICAgfQoKICAgLy8gcmV0dXJuIGZhbHNlOwogICBmb3IobGxpIGk9MTtpPD1uO2krKykKICAgewogICAgICAgaWYoZGlzdFtpXT09SU5GKQogICAgICAgIGNvdXQ8PDMwMDAwPDwiICI7CiAgICAgICAgZWxzZQogICAgICAgICAgICBjb3V0PDxkaXN0W2ldPDwiICI7CiAgIH0KICAgIAp9CgoKaW50IG1haW4oKXsKZmFzdGlvCmxsaSB0PTE7Ci8vY2luPj50OwpjaGFuZGFuMigpOwp3aGlsZSh0LS0pIHsKICAgIGxsaSBuOwogICAgY2luPj5uOwogICAgCiAgICAvLyB2ZWN0b3Igb2YgcGFpciA8Y29zdCAsIG5vZGU+CiAgICB2ZWN0b3I8cGlpPiBhZGpbbisxXTsKICAgIAogICAgbGxpIG07CiAgICBjaW4+Pm07CiAgICBsbGkgZHBbbl1bbl07CiAgICBsb29wKGksbikKICAgICAgICB7CiAgICAgICAgICAgIGxvb3AoaixuKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBpZihpPT1qKQogICAgICAgICAgICAgICAgICAgIGRwW2ldW2pdPTA7CiAgICAgICAgICAgICAgICBlbHNlCiAgICAgICAgICAgICAgICAgICAgZHBbaV1bal0gPSBJTkY7CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICBsb29wKGksbSkKICAgIHsKICAgICAgICBsbGkgeCx5LGNvc3Q7CiAgICAgICAgY2luPj54Pj55Pj5jb3N0OwogICAgICAgIC0teDsKICAgICAgICB5LS07CiAgICAgICAgZHBbeF1beF09MDsKICAgICAgICBkcFt5XVt5XT0wOwogICAgICAgIGRwW3hdW3ldPShjb3N0KTsKICAgICAgICBhZGpbeCsxXS5wYih7Y29zdCAsIHkrMX0pOwogICAgfQogICAgCiAgICBsb29wKGssbikKICAgIHsKICAgICAgICBsb29wKGksbikKICAgICAgICB7CiAgICAgICAgICAgIGxvb3AoaixuKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBpZihkcFtpXVtrXSE9SU5GIGFuZCBkcFtrXVtqXSE9SU5GICkKICAgICAgICAgICAgICAgIGRwW2ldW2pdID0gbWluKGRwW2ldW2pdICwgZHBbaV1ba10rZHBba11bal0pOwogICAgICAgICAgICB9CiAgICAgICAgfQogICAgfQogICAgY291dDw8IkJ5IGZsb3lkIHdhcnNoYWxsXG4iOwoKICAgIGxvb3AoaSxuKQogICAgewogICAgICAgIGlmKGRwWzBdW2ldPjMwMDAwKQogICAgICAgICAgICBjb3V0PDwzMDAwMDw8IiAiOwogICAgICAgIGVsc2UKICAgICAgICAgICAgY291dDw8ZHBbMF1baV08PCIgIjsKICAgIH0KICAgIGNvdXQ8PGVuZGw7CgkKCWNvdXQ8PCJCeSBiZWxsbWFuIGZvcmRcbiI7CgogICAgaXNOZWdDeWNsZShhZGosMSxuKTsKICB9CnJldHVybiAwOwp9Cg==