কম্পিউটার

একটি নির্দিষ্ট শহর থেকে একটি রাউন্ড ট্রিপ সম্ভব কিনা তা খুঁজে বের করতে C++ প্রোগ্রাম


ধরুন, n শহর আছে এবং m রাস্তাগুলি তাদের সংযুক্ত করছে। প্রতিটি রাস্তা একমুখী, এবং উৎস শহর থেকে গন্তব্য শহরে পৌঁছতে এটি একটি নির্দিষ্ট পরিমাণ সময় নেয়। রাস্তার তথ্য অ্যারে রাস্তাগুলিতে দেওয়া হয় যেখানে প্রতিটি উপাদান বিন্যাসের (উৎস, গন্তব্য, সময়)। এখন, একজন ব্যক্তি এক শহর থেকে অন্য শহরে ভ্রমণ করছেন এবং ট্রিপটি একটি রাউন্ড ট্রিপ হতে হবে। একটি ট্রিপকে রাউন্ড-ট্রিপ বলা যেতে পারে যখন ব্যক্তি একটি নির্দিষ্ট শহর থেকে শুরু করে, এক বা একাধিক রাস্তা দিয়ে যায় এবং একই শহরে ট্রিপ শেষ করে। তাই প্রতিটি শহরের জন্য, সেই নির্দিষ্ট শহর থেকে রাউন্ড-ট্রিপ সম্ভব কিনা তা নির্ধারণ করতে হবে। যদি সম্ভব হয়, রাউন্ড-ট্রিপ করার জন্য প্রয়োজনীয় সময়টি প্রিন্ট করুন বা অন্যথায় প্রিন্ট করুন -1।

সুতরাং, যদি ইনপুট হয় n =4, m =4, রাস্তা ={{1, 2, 5}, {2, 3, 8}, {3, 4, 7}, {4, 1, 6}} , তাহলে আউটপুট হবে:26 26 26 26। প্রতিটি শহর থেকে, একটি রাউন্ড-ট্রিপ করতে সময় লাগে 26।

এটি সমাধান করতে, আমরা এই পদক্ষেপগুলি অনুসরণ করব -

Define one 2D array graph(n) of pairs
for initialize i := 0, when i < m, update (increase i by 1), do:
   x := first value of roads[i]
   y := second value of roads[i]
   z := third value of roads[i]
   decrease x and y by 1
   insert pair (y, z) at the end of graph[x]
for initialize i := 0, when i < n, update (increase i by 1), do:
   q := a new priority queue
   Define an array dst
   insert pair (0, i) at the top of q
   while size of q is non-zero, do:
      pair p := top value of q
      delete the top element from q
      dt := first value of p
      curr := second value of p
      if dst[curr] is same as 0, then:
         dst[curr] := dt
         Come out from the loop
      if dst[curr] is not equal to -1, then:
         Ignore following part, skip to the next iteration
      dst[curr] := dt
      for element next in graph[curr], do:
         tp := first value of next
         cst := second value of next
         insert pair(dt + cst, tp) at the top of q
   if dst[i] is same as 0, then:
      dst[i] := -1
   print(dst[i])

উদাহরণ

আরো ভালোভাবে বোঝার জন্য আসুন নিচের বাস্তবায়ন দেখি -

#include <bits/stdc++.h>
using namespace std;
const int INF = 1e9;
const int modval = (int) 1e9 + 7;
#define N 100
void solve(int n, int m, vector<tuple<int, int, int>> roads ) {
   vector<vector<pair<int, int>>> graph(n);
   for(int i = 0; i < m; i++) {
      int x, y, z;
      tie(x, y, z) = roads[i];
      x--; y--;
      graph[x].emplace_back(y, z);
   }
   for(int i = 0; i < n; i++) {
      priority_queue<pair<int, int>> q;
      vector<int> dst(n, -1);
      q.emplace(0, i);
      while(q.size()){
         pair<int, int> p = q.top();
         q.pop();
         int curr, dt;
         tie(dt, curr) = p;
         if(dst[curr] == 0) {
            dst[curr] = dt;
            break;
         }
         if(dst[curr] != -1)
            continue;
         dst[curr] = dt;
         for(auto next : graph[curr]){
            int tp, cst;
            tie(tp, cst) = next;
            q.emplace(dt + cst, tp);
         }
      }
      if(dst[i] == 0)
      dst[i] = -1;
      cout<< dst[i]<< endl;
   }
}
int main() {
   int n = 4, m = 4;
   vector<tuple<int, int, int>> roads = {{1, 2, 5}, {2, 3, 8}, {3, 4, 7}, {4, 1, 6}};
   solve(n, m, roads);
   return 0;
}

ইনপুট

4, 4, {{1, 2, 5}, {2, 3, 8}, {3, 4, 7}, {4, 1, 6}}

আউটপুট

26
26
26
26

  1. একটি গ্রাফে সুপার শীর্ষবিন্দুগুলি খুঁজে বের করার জন্য C++ প্রোগ্রাম

  2. একটি প্রদত্ত গ্রাফে সেতুর প্রান্তের সংখ্যা খুঁজে বের করার জন্য C++ প্রোগ্রাম

  3. একটি গ্রাফ থেকে সর্বাধিক স্কোর কমানো যেতে পারে তা খুঁজে বের করতে C++ প্রোগ্রাম

  4. C++ এ যতটা সম্ভব জমি থেকে যতদূর সম্ভব