#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<ll,int> ii;
typedef vector<int> vi;
const int MAX_N=3e5+10;
const ll MAX=1e15;
ll ma[MAX_N];
ll dis[MAX_N];
vector<vi> G;
vector<ll> a,b,w;
int n,m;
bool pri[MAX_N];
vector<ii> bfs(int u){
for(int i=0;i<n;i++) dis[i]=MAX;
dis[u]=0;
priority_queue<ii, vector<ii>, greater<ii> > pq;
pq.push(ii(0,u));
while(!pq.empty()){
int x=pq.top().second;
int k=pq.top().first;
pq.pop();
for(auto &v:G[x]){
int y;
if(x==a[v]) y=b[v];
else y=a[v];
if(dis[y]>dis[x]+w[v]){
dis[y]=dis[x]+w[v];
pq.push(ii(dis[y],y));
}
}
}
memset(pri,0,sizeof pri);
vector<ii> path;
int st,en;;
if(u==0) {
en=0;
st=n-1;
}
else{
st=0;
en=n-1;
}
u=st;
while(u!=en){
int id=-1;
ll mi=MAX;
for(auto &v:G[u]){
int y;
if(u==a[v]) y=b[v];
else y=a[v];
if(mi>dis[y]){
id=v; mi=dis[y];
}
}
if(u==a[id]) u=b[id];
else u=a[id];
path.push_back(ii(u,id));
}
reverse(path.begin(),path.end());
return path;
}
int main(){
cin>>n>>m;
G.resize(n+1);
for(int i=0;i<m;i++){
int x,y,z; cin>>x>>y>>z;
x--; y--;
a.push_back(x);
b.push_back(y);
w.push_back(z);
G[x].push_back(i);
G[y].push_back(i);
}
ma[m]=0;
for(int i=m-1;i>=0;i--){
ma[i]=max(ma[i+1],w[i+1]);
}
ll res=0;
if(m==n-1){
vector<ii> path=bfs(0);
for(int i=0;i<path.size();i++){
int id=path[i].second;
if(id==m-1) continue;
ll rp=dis[n-1]+ma[id];
res=max(res,rp);
}
}
else{
for(int i=0;i<m-1;i++){
w[i]+=ma[i];
bfs(0);
res=max(res,dis[n-1]);
w[i]-=ma[i];
}
}
cout<<res<<endl;
}
Compilation message
Aesthetic.cpp: In function 'std::vector<std::pair<long long int, int> > bfs(int)':
Aesthetic.cpp:21:9: warning: unused variable 'k' [-Wunused-variable]
21 | int k=pq.top().first;
| ^
Aesthetic.cpp: In function 'int main()':
Aesthetic.cpp:83:18: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<long long int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
83 | for(int i=0;i<path.size();i++){
| ~^~~~~~~~~~~~
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
580 KB |
Output is correct |
2 |
Correct |
2 ms |
560 KB |
Output is correct |
3 |
Correct |
2 ms |
588 KB |
Output is correct |
4 |
Correct |
2 ms |
588 KB |
Output is correct |
5 |
Correct |
2 ms |
588 KB |
Output is correct |
6 |
Correct |
2 ms |
588 KB |
Output is correct |
7 |
Correct |
2 ms |
588 KB |
Output is correct |
8 |
Correct |
1 ms |
588 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
580 KB |
Output is correct |
2 |
Correct |
2 ms |
560 KB |
Output is correct |
3 |
Correct |
2 ms |
588 KB |
Output is correct |
4 |
Correct |
2 ms |
588 KB |
Output is correct |
5 |
Correct |
2 ms |
588 KB |
Output is correct |
6 |
Correct |
2 ms |
588 KB |
Output is correct |
7 |
Correct |
2 ms |
588 KB |
Output is correct |
8 |
Correct |
1 ms |
588 KB |
Output is correct |
9 |
Correct |
363 ms |
792 KB |
Output is correct |
10 |
Correct |
372 ms |
796 KB |
Output is correct |
11 |
Correct |
246 ms |
788 KB |
Output is correct |
12 |
Correct |
261 ms |
716 KB |
Output is correct |
13 |
Correct |
170 ms |
708 KB |
Output is correct |
14 |
Correct |
174 ms |
716 KB |
Output is correct |
15 |
Correct |
188 ms |
748 KB |
Output is correct |
16 |
Correct |
192 ms |
716 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
508 ms |
34804 KB |
Output is correct |
2 |
Correct |
558 ms |
35012 KB |
Output is correct |
3 |
Correct |
492 ms |
34588 KB |
Output is correct |
4 |
Correct |
496 ms |
34564 KB |
Output is correct |
5 |
Correct |
507 ms |
34628 KB |
Output is correct |
6 |
Correct |
500 ms |
35444 KB |
Output is correct |
7 |
Correct |
518 ms |
35312 KB |
Output is correct |
8 |
Correct |
525 ms |
35496 KB |
Output is correct |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Execution timed out |
2023 ms |
35448 KB |
Time limit exceeded |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Execution timed out |
2083 ms |
29624 KB |
Time limit exceeded |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Execution timed out |
2083 ms |
29624 KB |
Time limit exceeded |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
2 ms |
580 KB |
Output is correct |
2 |
Correct |
2 ms |
560 KB |
Output is correct |
3 |
Correct |
2 ms |
588 KB |
Output is correct |
4 |
Correct |
2 ms |
588 KB |
Output is correct |
5 |
Correct |
2 ms |
588 KB |
Output is correct |
6 |
Correct |
2 ms |
588 KB |
Output is correct |
7 |
Correct |
2 ms |
588 KB |
Output is correct |
8 |
Correct |
1 ms |
588 KB |
Output is correct |
9 |
Correct |
363 ms |
792 KB |
Output is correct |
10 |
Correct |
372 ms |
796 KB |
Output is correct |
11 |
Correct |
246 ms |
788 KB |
Output is correct |
12 |
Correct |
261 ms |
716 KB |
Output is correct |
13 |
Correct |
170 ms |
708 KB |
Output is correct |
14 |
Correct |
174 ms |
716 KB |
Output is correct |
15 |
Correct |
188 ms |
748 KB |
Output is correct |
16 |
Correct |
192 ms |
716 KB |
Output is correct |
17 |
Correct |
508 ms |
34804 KB |
Output is correct |
18 |
Correct |
558 ms |
35012 KB |
Output is correct |
19 |
Correct |
492 ms |
34588 KB |
Output is correct |
20 |
Correct |
496 ms |
34564 KB |
Output is correct |
21 |
Correct |
507 ms |
34628 KB |
Output is correct |
22 |
Correct |
500 ms |
35444 KB |
Output is correct |
23 |
Correct |
518 ms |
35312 KB |
Output is correct |
24 |
Correct |
525 ms |
35496 KB |
Output is correct |
25 |
Execution timed out |
2023 ms |
35448 KB |
Time limit exceeded |
26 |
Halted |
0 ms |
0 KB |
- |