提交记录 4266


用户 题目 状态 得分 用时 内存 语言 代码长度
ZqlwMatt noi18a. 【NOI2018】归程 Accepted 100 1.394 s 68832 KB C++ 2.30 KB
提交时间 评测时间
2018-07-19 13:54:39 2020-07-31 22:48:17
#include <iostream>
#include <cstdio>
#include <cctype>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std;
#define re register int
#define rep(i,a,b) for(re i=(a);i<=(b);++i)
#define pii pair<ll,int>
#define fi first
#define se second
const int N = 400002, M = 1000002;
typedef long long ll;
template <class T>inline void read(T &x) {
	x=0; int f=1; char ch=getchar();
	while(!isdigit(ch)) {if(ch=='-')f=-1;ch=getchar();}
	while(isdigit(ch)) {x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
	x*=f;
}
int cnt, nxt[M], head[N], to[M], w[M];
#define add(u,v,l) (nxt[++cnt]=head[u],head[u]=cnt,to[cnt]=v,w[cnt]=l)
#define add2(u,v) (nxt[++cnt]=head[u],head[u]=cnt,to[cnt]=v)
#define clear_Edge (memset(head,0,sizeof head),cnt=0)
#define travel(u) for(re i=head[u];i;i=nxt[i])
struct Edge {
	int u, v, H;
	inline bool operator < (const Edge &rhs)const{return H>rhs.H;}
} e[M];
int fa[N];
int find(int x){return !fa[x]?x:fa[x]=find(fa[x]);}

priority_queue<pii,vector<pii>,greater<pii> > q;
ll dis[N]; bool vis[N];
inline void Dijkstra() {
	memset(vis, 0, sizeof vis); memset(dis, 0x7f, sizeof dis); dis[1]=0;
	q.push(make_pair(0,1));
	int v;
	while(!q.empty()) {
		pii u=q.top(); q.pop();
		if(vis[u.se])	continue;
		vis[u.se]=1;
		travel(u.se) { v = to[i];
			if(dis[v] > u.fi+w[i]) {
				dis[v] = u.fi+w[i];
				q.push(make_pair(dis[v],v));
			}
		}
	}
}

int T, n, m, id, H[N], f[N][21];
ll d[N], lastans;
void dfs(int u) {
	travel(u)
		dfs(to[i]),f[to[i]][0]=u,d[u]=min(d[u],d[to[i]]);
	if(u<=n)	d[u]=dis[u];
}
inline void init() {rep(j,1,20)rep(i,1,id)f[i][j]=f[f[i][j-1]][j-1];}
inline void rec() {
	clear_Edge; memset(fa,0,sizeof fa);
	rep(i,1,m) {
		int p=find(e[i].u), q=find(e[i].v);
		if(p!=q) {
			fa[p]=fa[q]=++id; // new Node
			add2(id,p), add2(id,q); //Kruskal重构树
			H[id] = e[i].H;
		}
	}
	memset(d,0x7f,sizeof d); dfs(id); init();
}
int main() {
	static int u, v, l, a, Q, K, S, p;
	read(T);
	while(T--) {
		read(n), read(m); id=n; clear_Edge;
		rep(i,1,m) {
			read(u),read(v),read(l),read(a);
			add(u,v,l); add(v,u,l); e[i]=(Edge){u,v,a};
		}
		sort(e+1, e+m+1);
		Dijkstra();  rec();

		read(Q), read(K), read(S); lastans=0;
		while(Q--) {
			read(v), read(p);
			v = (v+K*lastans-1)%n+1;
			p = (p+K*lastans)%(S+1);
			for(int i=20;i>=0;--i)	if(H[f[v][i]]>p)v=f[v][i];
			printf("%lld\n", lastans=d[v]);
		}
	}
	return 0;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #11.599 ms9 MB + 596 KBAcceptedScore: 5

Testcase #21.624 ms9 MB + 612 KBAcceptedScore: 5

Testcase #31.758 ms9 MB + 628 KBAcceptedScore: 5

Testcase #41.919 ms9 MB + 640 KBAcceptedScore: 5

Testcase #55.48 ms10 MB + 36 KBAcceptedScore: 5

Testcase #6738.624 ms59 MB + 276 KBAcceptedScore: 5

Testcase #74.699 ms9 MB + 988 KBAcceptedScore: 5

Testcase #84.695 ms9 MB + 996 KBAcceptedScore: 5

Testcase #94.69 ms9 MB + 992 KBAcceptedScore: 5

Testcase #10569.304 ms53 MB + 656 KBAcceptedScore: 5

Testcase #11569.691 ms53 MB + 664 KBAcceptedScore: 5

Testcase #12831.491 ms63 MB + 756 KBAcceptedScore: 5

Testcase #13830.857 ms63 MB + 760 KBAcceptedScore: 5

Testcase #14831.15 ms63 MB + 784 KBAcceptedScore: 5

Testcase #156.045 ms10 MB + 60 KBAcceptedScore: 5

Testcase #166.058 ms10 MB + 64 KBAcceptedScore: 5

Testcase #17831.318 ms63 MB + 760 KBAcceptedScore: 5

Testcase #18830.951 ms63 MB + 760 KBAcceptedScore: 5

Testcase #191.389 s67 MB + 204 KBAcceptedScore: 5

Testcase #201.394 s67 MB + 224 KBAcceptedScore: 5


Judge Duck Online | 评测鸭在线
Server Time: 2025-01-18 20:55:40 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠