Cod sursa(job #3227256)

Utilizator thinkphpAdrian Statescu thinkphp Data 28 aprilie 2024 19:45:50
Problema Algoritmul Bellman-Ford Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.82 kb
#include <iostream>
#include <fstream>
#include <queue>
#include <bitset>
#define FIN "bellmanford.in"
#define FOUT "bellmanford.out"
#define MAXN 50005
#define oo ((1LL<<31)-1)

using namespace std;

int nodes,
    edges;

vector< pair<int,int> > Graph[ MAXN ];
int distMin[ MAXN ];

queue<int> Queue;
bitset<MAXN> inQueue;
int countInQueue[MAXN];
bool negative_cycle = false;

void readData() {
     int x,
         y,
         cost;
         ifstream fin(FIN);

         fin>>nodes>>edges;

         while(edges--) {

             fin>>x>>y>>cost;

             Graph[ x ].push_back({y, cost});
         }

         fin.close();
}

void BellmanFord() {

     for(int i = 2; i <= nodes; ++i) distMin[i] = oo;

     distMin[ 1 ] = 0;

     Queue.push(1);

     inQueue[ 1 ] = true;

     while(!Queue.empty() && !negative_cycle) {

          int node = Queue.front();

          Queue.pop();

          inQueue[ node ] = false;

          for(auto it: Graph[ node ]) {

              if(distMin[ it.first ] > distMin[ node ] + it.second) {

                 distMin[ it.first ] = distMin[ node ] + it.second;

                 if(!inQueue[ it.first ]) {

                     if(countInQueue[ it.first ] > nodes) {

                        negative_cycle = true;

                     } else {

                        Queue.push( it.first );

                        inQueue[ it.first ] = true;

                        countInQueue[it.first]++;
                     }


                 }
              }
          }
     }

}

void writeData() {

     ofstream fout( FOUT );

     if( negative_cycle ) {

       fout<<"Ciclu negativ!";

     } else {

       for( int i = 2; i <= nodes; i++ )

       fout<<distMin[ i ]<<" ";
     }

     fout.close();
}


int main(int argc, char const *argv[]) {

  readData();
  BellmanFord();
  writeData();

  return 0;
}