求助 二分 WA了#12 #13

P1462 通往奥格瑞玛的道路

underline__jian @ 2022-03-03 22:04:53

#include<iostream>
#include<algorithm>
#include<queue>
#define re register
using namespace std;
const int N=5000010,INF=0x3f3f3f3f;
long long n,m,b,c[N],cc[N],dis[N],ans;
bool vis[N],flag[N];
priority_queue<pair<long,long> >que;
struct node{
    int to,head,nxt;
    long long v;
}e[N];
int tot;
inline void add(long long x,long long y,long long z){
    e[++tot].to=y;
    e[tot].v=z;
    e[tot].nxt=e[x].head;
    e[x].head=tot;
}
inline void dijkstra(){
    for(re int i=1;i<=n;i++){
        vis[i]=false;
        dis[i]=INF;
    }
    dis[1]=0;
    que.push(make_pair(0,1));
    while(!que.empty()){
        int x=que.top().second;
        que.pop();
        if(vis[x]) continue;
        vis[x]=true;
        for(re int i=e[x].head;i;i=e[i].nxt){
            int v=e[i].to;
            if(dis[v]>dis[x]+e[i].v&&flag[x]==0&&flag[v]==0){
                dis[v]=dis[x]+e[i].v;
                que.push(make_pair(-dis[v],v));
            }
        }
    }
}
inline bool check(long long x){
    for(re int i=1;i<=n;i++) flag[i]=false;
    for(re int i=1;i<=n;i++) if(c[i]>x) flag[i]=true;
    dijkstra();
    if(dis[n]==INF||dis[n]>=b) return false;
    return true;
}
inline long long read(){
    long long x=0,y=1;
    char ch=getchar();
    while(ch<'0'||ch>'9'){
        if(ch=='-') y=-y;
        ch=getchar();
    }
    while(ch>='0'&&ch<='9'){
        x=x*10+ch-'0';
        ch=getchar();
    }
    return x*y;
}
int main(){
    n=read(),m=read(),b=read();
    for(re int i=1;i<=n;i++){
        c[i]=read();
        cc[i]=c[i];
    }
    for(re int i=1;i<=m;i++){
        long long x=read(),y=read(),z=read();
        add(x,y,z);
        add(y,x,z);
    }
    dijkstra();
    if(dis[n]==INF||dis[n]>=b){
        printf("AFK");
        exit(0);
    }
    sort(cc+1,cc+1+n);
    ans=cc[n];
    int l=1,r=n;
    while(l<=r){
        long long mid=(l+r)>>1;
        if(check(cc[mid])==true){
            ans=cc[mid];
            r=mid-1;
        }
        else l=mid+1;
    }
    printf("%lld",ans);
    return 0;
}

by StarLbright40 @ 2022-03-04 18:27:20

这里有一个 long 和 long long 不分的人我们一起嘲笑他


by StarLbright40 @ 2022-03-04 18:29:39

@include 你开 pair<long,long> 那么它里面存的两个数都是 long 类型的,但是本题的最短路需要开 long long,不确定还有没有别的问题


by underline__jian @ 2022-03-04 19:31:03

@星光0000 啊哈哈,我是SB 谢谢


by underline__jian @ 2022-03-04 19:32:07

但是问题好像并不是这个


by underline__jian @ 2022-03-04 19:32:35

@int524288 快来


by StarLbright40 @ 2022-03-04 19:35:16

@include

如果他的血量降低至负数,则他就无法到达奥格瑞玛。

也就是说,如果他的血量降到 0,这是可行的


by underline__jian @ 2022-03-04 19:40:09

if(dis[n]==INF||dis[n]>b)

您的意思是这个?

验证码JCFK祭


by underline__jian @ 2022-03-04 19:41:12

@星光0000 过了,谢谢

int524288可以不用来了


by huangzitai @ 2022-03-04 20:49:30

@include 你私信发给我的是 P1456 啊 /yun


by underline__jian @ 2022-03-04 21:48:40

@int524288 啊这


|