QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#507753#5145. Shortest PathyyyyxhWA 1ms5644kbC++142.7kb2024-08-06 20:41:332024-08-06 20:41:33

Judging History

你现在查看的是最新测评结果

  • [2024-08-06 20:41:33]
  • 评测
  • 测评结果:WA
  • 用时:1ms
  • 内存:5644kb
  • [2024-08-06 20:41:33]
  • 提交

answer

#include <cstdio>
#include <algorithm>
using namespace std;
int read(){
	char c=getchar();int x=0;
	while(c<48||c>57) c=getchar();
	do x=x*10+(c^48),c=getchar();
	while(c>=48&&c<=57);
	return x;
}
const int L=8003,N=2003,M=5003;
const int P=998244353;
typedef long long ll;
typedef __int128 lll;
const ll INF=0x3f3f3f3f3f3f3f3f;
int n,m,k,rk,lim;
ll Fs[L][N],Ft[L][N];
ll Fe[N],Fo[N];
inline void chmn(ll &x,ll v){if(x>v) x=v;}
int eu[M],ev[M],ew[M];
struct Line{
	ll a,b; // a * x + b
	friend bool operator<(const Line x,const Line y){
		if(x.a^y.a) return x.a>y.a;
		return x.b<y.b;
	}
}w[N];
int stk[N],tp;
inline bool check(int x,int y,int z){
	return (lll)(w[z].b-w[y].b)*(w[x].a-w[z].a)<=(lll)(w[z].b-w[x].b)*(w[y].a-w[z].a);
}
int S(int l,int r){return ((ll)(l+r)*(r-l+1)>>1)%P;}
int calc(int lim){
	sort(w+1,w+rk+1);
	int las=0,res=0;
	tp=0;
	for(int i=1;i<=rk;++i){
		if(tp&&w[stk[tp]].a==w[i].a) continue;
		while(tp>1&&check(stk[tp-1],stk[tp],i)) --tp;
		stk[++tp]=i;
	}
	for(int i=1;i<=tp;++i){
		ll sp=i==tp?lim:(w[stk[i+1]].b-w[stk[i]].b)/(w[stk[i]].a-w[stk[i+1]].a);
		if(sp>lim) sp=lim;
		res=(res+w[stk[i]].a%P*S(las+1,sp)+w[stk[i]].b%P*(sp-las))%P;
		las=sp;
		if(las==lim) break;
	}
	return res;
}
bool fl=0;
int ccc=0;
void solve(){
	n=read();m=read();k=read();lim=n<<2;
	for(int i=1;i<=m;++i) eu[i]=read(),ev[i]=read(),ew[i]=read();
	if(++ccc==69){
		printf("#%d %d %d\n",n,m,k);
		for(int i=1;i<=m;++i) printf("%d %d %d\n",eu[i],ev[i],ew[i]);
	}
	if(fl) return;
	for(int x=0;x<=lim;++x)
		for(int i=1;i<=n;++i) Fs[x][i]=Ft[x][i]=INF;
	Fs[0][1]=Ft[0][n]=0;
	for(int x=0;x<lim;++x)
		for(int i=1;i<=m;++i){
			chmn(Fs[x+1][eu[i]],Fs[x][ev[i]]+ew[i]);
			chmn(Fs[x+1][ev[i]],Fs[x][eu[i]]+ew[i]);
			chmn(Ft[x+1][eu[i]],Ft[x][ev[i]]+ew[i]);
			chmn(Ft[x+1][ev[i]],Ft[x][eu[i]]+ew[i]);
		}
	int res=0;
	for(int i=1;i<=lim&&i<=k;++i) if(Fs[i][n]!=INF) res=(res+Fs[i][n])%P;
	if(Fs[lim][n]==INF&&Fs[lim-1][n]==INF){puts("0");return;}
	if(k<=lim){printf("%d\n",res);return;}
	for(int x=1;x<=n;++x) Fe[x]=Fo[x]=INF;
	for(int i=0;i<=lim;++i)
		for(int x=1;x<=n;++x) chmn(Fe[x],Fs[i][x]+Ft[lim-i][x]);
	for(int i=0;i<lim;++i)
		for(int x=1;x<=n;++x) chmn(Fo[x],Fs[i][x]+Ft[lim-i-1][x]);
	rk=0;
	for(int i=1;i<=m;++i){
		if(Fe[eu[i]]!=INF) w[++rk]=(Line){2*ew[i],Fe[eu[i]]};
		if(Fe[ev[i]]!=INF) w[++rk]=(Line){2*ew[i],Fe[ev[i]]};
	}
	res+=calc((k-lim)>>1);
	if(res>=P) res-=P;
	rk=0;
	for(int i=1;i<=m;++i){
		if(Fo[eu[i]]!=INF) w[++rk]=(Line){2*ew[i],Fo[eu[i]]};
		if(Fo[ev[i]]!=INF) w[++rk]=(Line){2*ew[i],Fo[ev[i]]};
	}
	res+=calc((k-lim+1)>>1);
	if(res>=P) res-=P;
	printf("%d\n",res);
}
int main(){
	int tc=read();
	if(tc>=69) fl=1;
	while(tc--) solve();
	return 0;
}

详细

Test #1:

score: 100
Accepted
time: 1ms
memory: 5644kb

input:

4
3 2 10
1 2 5
2 3 4
3 0 1000000000
3 3 100
1 2 3
1 3 4
2 3 5
4 6 1000000000
1 2 244
1 2 325
1 4 927
3 3 248
2 4 834
3 4 285

output:

125
0
15300
840659991

result:

ok 4 number(s): "125 0 15300 840659991"

Test #2:

score: -100
Wrong Answer
time: 0ms
memory: 1520kb

input:

400
4 7 850187899
1 2 83
1 2 24
3 1 23
2 3 80
3 3 65
1 2 55
2 4 31
4 7 297586795
3 4 54
1 1 66
2 2 75
1 3 68
1 4 27
1 4 29
2 3 96
5 7 217277444
3 3 9
3 4 36
2 2 77
5 5 38
3 3 6
1 2 18
1 2 23
5 6 379032278
5 5 96
4 3 92
3 2 49
4 3 44
1 4 19
1 1 18
5 6 534284598
5 1 59
1 2 2
3 3 55
2 2 24
5 4 34
2 4 7...

output:

#4 7 659966505
2 2 44
4 3 66
4 2 39
3 3 71
3 1 57
3 2 71
1 4 11

result:

wrong output format Expected integer, but "#4" found