Submission #1157682

#TimeUsernameProblemLanguageResultExecution timeMemory
1157682shnEscape Route (JOI21_escape_route)C++20
0 / 100
9093 ms111940 KiB
#include "escape_route.h"
#include <bits/stdc++.h>
using namespace std;
#define pb push_back
const int N = 92;

struct node{
	long long w , lim;
	int to;
};

vector < node > g[N];

vector<long long> calculate_necessary_time(int n, int m, long long s, int q, vector<int> a, vector<int> b,vector<long long> l, vector<long long> c, vector<int> v,vector<int> u, vector<long long> t){
	vector < long long > ans;
	for(int i = 0; i < m; i++){
		g[a[i]].pb({l[i] , c[i] , b[i]});
		g[b[i]].pb({l[i] , c[i] , a[i]});
	}
	for(int i = 0; i < q; i++){
		set < pair < pair < int , long long > , int > > st;
		st.insert({{0 , t[i]} , v[i]});
		pair < int , long long > dst[n];
		for(int i = 0; i < n; i++) dst[i] = {n + 1 , n + 1};
		dst[v[i]] = {0 , t[i]};
		while(st.size()){
			int v = st.begin() -> second;
			st.erase(st.begin());
			for(node it : g[v]){
				int d = dst[v].first , tim = dst[v].second;
				if(0 <= tim && tim <= it.lim - it.w){
					tim += it.w;
				}
				else{
					tim = it.w;
					d++;
				}
				if(dst[it.to].first > d || dst[it.to].first == d && dst[it.to].second > tim){
					st.erase({dst[it.to] , it.to});
					dst[it.to] = {d , tim};
					st.insert({dst[it.to] , it.to});
				}
			}
		}
		ans.pb(dst[u[i]].first * s + dst[u[i]].second - t[i]);
	}
	return ans;
}

// int main(){
	// int n , m;
	// long long s;
	// int q;
	// cin >> n >> m >> s >> q;
	// vector < int > a , b;
	// vector < long long > l , c;
	// for(int i = 0; i < m; i++){
		// int x , y , z , t;
		// cin >> x >> y >> z >> t;
		// a.pb(x);
		// b.pb(y);
		// l.pb(z);
		// c.pb(t);
	// }
	// vector < int > v , u;
	// vector < long long > t;
	// for(int i = 0; i < q; i++){
		// int x , y , z;
		// cin >> x >> y >> z;
		// v.pb(x);
		// u.pb(y);
		// t.pb(z);
	// }
	// vector < long long > ans = calculate_necessary_time(n , m , s , q , a , b , l , c , v , u , t);
	// for(auto it : ans){
		// cout << it << '\n';
	// }
// }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...