社区讨论

佬们,#1#2一直通不过,82分,求助

P1807最长路参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@m6ekx1pd
此快照首次捕获于
2025/01/27 12:59
去年
此快照最后确认于
2025/11/04 10:15
4 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
const int N = 1510, M = 5e4+10;
struct edge{
    int a,b,c;
}edges[M];
int n,m;
int dist[N],backup[N];

void bell(){
    fill_n(dist,N,INT_MIN);
    dist[1] = 0;
    for(int i = 0; i < n; i++){
        memcpy(backup,dist,sizeof(dist));
        for(int j = 0; j < m; j++){
            auto e = edges[j];
            dist[e.b] = max(dist[e.b],backup[e.a]+e.c);
        }
    }
}

int main(){
    cin>>n>>m;
    for(int i = 0; i < m; i++){
        int u,v,w;
        cin>>u>>v>>w;
        edges[i] = {u,v,w};
    }
    bell();
    if(dist[n] < INT_MIN/2) printf("-1");
    else printf("%d",dist[n]);
    return 0;
}

回复

2 条回复,欢迎继续交流。

正在加载回复...