非常迷的一道题啊

我觉得挺对的版本只得了30

总之就是Floyd·改,开两个数组,一个是d[i][j]就是普通的只有边权的最短路,a[i][j]是题目要求的那种

具体改的地方是把枚举中转点的地方把中转点按从小到大的顺序枚举,d[i][j]按照套路更新即可,然后a[i][j]从a[i][j]原数和d[i][j]+max(c[i],c[j],c[中转点])中取min

证明的话是最短路不一定是最终答案,能更新这个答案的一定是最大点更小一些的另一条路,所以按点权顺序更新能保证把这种情况全部更新

#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
const int N=255,inf=1e9+7;
int n,m,q,a[N][N],d[N][N],v[N];
struct qwe
{
int p,v;
}c[N];
bool cmp(const qwe &x,const qwe &y)
{
return x.v<y.v;
}
int read()
{
int r=0,f=1;
char p=getchar();
while(p>'9'||p<'0')
{
if(p=='-')
f=-1;
p=getchar();
}
while(p>='0'&&p<='9')
{
r=r*10+p-48;
p=getchar();
}
return r*f;
}
int main()
{
n=read(),m=read(),q=read();
for(int i=1;i<=n;i++)
v[i]=d[i][i]=a[i][i]=c[i].v=read(),c[i].p=i;
sort(c+1,c+1+n,cmp);
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(i!=j)
a[i][j]=d[i][j]=inf;
for(int i=1;i<=m;i++)
{
int x=read(),y=read(),z=read();
d[x][y]=d[y][x]=min(d[x][y],z);
}
for(int k=1;k<=n;k++)
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
d[i][j]=min(d[i][j],d[i][c[k].p]+d[c[k].p][j]),a[i][j]=min(a[i][j],d[i][j]+max(max(v[i],v[j]),c[k].v));
while(q--)
{
int x=read(),y=read();
printf("%d\n",a[x][y]);
}
return 0;
}

我觉得挺对的版本:

#include<iostream>
#include<cstdio>
using namespace std;
const int N=255,inf=1e9+7;
int n,m,q,a[N][N],c[N],mx[N][N];
int read()
{
int r=0,f=1;
char p=getchar();
while(p>'9'||p<'0')
{
if(p=='-')
f=-1;
p=getchar();
}
while(p>='0'&&p<='9')
{
r=r*10+p-48;
p=getchar();
}
return r*f;
}
int main()
{
n=read(),m=read(),q=read();
for(int i=1;i<=n;i++)
c[i]=read(),mx[i][i]=a[i][i]=c[i];
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(i!=j)
a[i][j]=mx[i][j]=inf;
for(int i=1;i<=m;i++)
{
int x=read(),y=read(),z=read();
if(a[x][y]>z+max(c[x],c[y]))
a[x][y]=a[y][x]=z+max(c[x],c[y]),mx[x][y]=mx[y][x]=max(c[x],c[y]);
}
for(int k=1;k<=n;k++)
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(a[i][j]>a[i][k]-mx[i][k]+a[k][j]-mx[k][j]+max(mx[i][k],mx[k][j]))
a[i][j]=a[i][k]-mx[i][k]+a[k][j]-mx[k][j]+max(mx[i][k],mx[k][j]),mx[i][j]=max(mx[i][k],mx[k][j]);
while(q--)
{
int x=read(),y=read();
printf("%d\n",a[x][y]);
}
return 0;
}

最新文章

  1. Python学习记录day5
  2. 实战使用Axure设计App,使用WebStorm开发(6) – 迈向后端
  3. HTML基础知识总结
  4. iOS开发-生成随机数
  5. 通过代码设置textview颜色
  6. 2015年最新中国知网CNKI免费账号直接入口
  7. c#解析xml字符串 分析 EntityName 时出错
  8. Hive学习之五 《Hive进阶—UDF操作案例》 详解
  9. MySQL Workbench导出数据库
  10. 一次非典型的SQL报错
  11. 快学Scala-第四章 映射和元组
  12. 1934: [Shoi2007]Vote 善意的投票
  13. 用超链接传递数组或get方式
  14. 201521123121 《Java程序设计》第14周学习总结
  15. Python shutil模块
  16. BZOJ4025 二分图 分治 并查集 二分图 带权并查集按秩合并
  17. 在远程桌面服务中配置RD网关直接访问内网
  18. 纯js实现文件下载并重命名功能
  19. [ADC]TI am4378 ADC采样设置问题(am335x类似)
  20. php $_SERVER[&#39;HTTP_USER_AGENT&#39;] 2

热门文章

  1. CEO的作用
  2. numpy——基础数组与计算
  3. 【NOIP2017练习&amp;BZOJ4998】星球联盟(强联通分量,并查集)
  4. openjudge7627 鸡蛋的硬度
  5. [bzoj3196][Tyvj1730]二逼平衡树_树套树_位置线段树套非旋转Treap/树状数组套主席树/权值线段树套位置线段树
  6. JavaScript为字符串添加样式
  7. Session&amp;Cookie 的介绍和使用
  8. springboot技术
  9. JSP的生命周期
  10. CentOS 7 es搭建测试