QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#507753 | #5145. Shortest Path | yyyyxh | WA | 1ms | 5644kb | C++14 | 2.7kb | 2024-08-06 20:41:33 | 2024-08-06 20:41:33 |
Judging History
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