Guest User

Untitled

a guest
Dec 26th, 2019
93
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.45 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. #define int long long
  3. using namespace std;
  4.  
  5.  
  6.  
  7. struct edge {
  8.         int v, w, x;
  9. };
  10.  
  11. const int N = 1e5 + 7, inf = 0x3f3f3f3f3f3f3f3f;
  12.  
  13. vector <edge> adj[N];
  14.  
  15. int d[N];
  16.  
  17.  
  18. int dijkstra(int x, int s, int t) {
  19.         memset(d, 0x3f, sizeof d);
  20.         d[s] = 0;
  21.         set <pair <int, int> > st; st.insert({0, s});
  22.         while(!st.empty()) {
  23.                 int u = st.begin() -> second; st.erase(st.begin());
  24.                 for(auto y: adj[u]) {
  25.                         if((y.x & x) == x && d[y.v] > d[u] + y.w) {
  26.                                 st.erase({d[y.v], y.v});
  27.                                 d[y.v] = d[u] + y.w;
  28.                                 st.insert({d[y.v], y.v});
  29.                         }
  30.                 }
  31.         }
  32.         return d[t];
  33. }
  34.  
  35. int32_t main() {
  36.         int n, m; cin >> n >> m;
  37.         for(int i = 1; i <= m; i++) {
  38.                 int u, v, w, x; cin >> u >> v >> w >> x;
  39.                 adj[u].push_back({v, w, x});
  40.                 adj[v].push_back({u, w, x});
  41.         }
  42.  
  43.         int s, t, k, val = 0; cin >> s >> t >> k;
  44.         int ans = inf;
  45.         for(int i = 30; i >= 0; i--) {
  46.                 if((k >> i) & 1) val ^= (1 << i);
  47.                 else {
  48.                         ans = min(ans, dijkstra(val ^ (1 << i), s, t));
  49.                 }
  50.         }
  51.  
  52.         ans = min(ans, dijkstra(k, s, t));
  53.  
  54.         if(ans >= inf) ans = -1;
  55.  
  56.  
  57.         cout << ans << endl;
  58.  
  59.  
  60. }
Advertisement
Add Comment
Please, Sign In to add comment