#define int long long???
  • 板块学术版
  • 楼主7hoth
  • 当前回复8
  • 已保存回复8
  • 发布时间2022/2/26 08:51
  • 上次更新2023/10/28 07:44:51
查看原帖
#define int long long???
354416
7hoth楼主2022/2/26 08:51

为什么

#define int long long

会影响这个代码的结果

#include<bits/stdc++.h>
#define int long long
using namespace std;

const int N = 510, M = 100010;
int ver[M],edge[M],head[N],nex[M];
int n,m,tot;
int state[N],dist[N];


void add(int x,int y,int z)
{
  
  ver[++tot]=y,edge[tot]=z;
  nex[tot]=head[x],head[x]=tot;
}

void dijkstra()
{
  memset(dist,0x3f,sizeof(dist));
  dist[1]=0;
  for(int i=0;i<n;i++)
    {
      int t=-1;
      for(int j=1;j<=n;j++)
        {
          if(!state[j]&&(t==-1||dist[j]<dist[t]))
          t=j;
        }
      state[t]=1;
      for(int j=head[t];j!=-1;j=nex[j])
        {
          int i=ver[j];
          dist[i]=min(dist[i],dist[t]+edge[j]);
          
        }
    }
}


signed main()
{
  memset(head,-1,sizeof(head));

  cin>>n>>m;
  for(int i=1;i<=m;i++)
    {
      int x,y,z;
      cin>>x>>y>>z;
      add(x,y,z);
    }
  dijkstra();

  if(dist[n]!=0x3f3f3f3f)
    cout<<dist[n]<<endl;
  else
    cout<<"-1";
  return 0;
}

2022/2/26 08:51
加载中...