题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4034

题意:

  有一个有向图,n个节点。给出两两节点之间的最短路长度,问你原图至少有多少条边。

  如果无解,输出"impossible"。

题解:

  因为在floyd中:

    if(dis[i][k] + dis[k][j] < dis[i][j])

      dis[i][j] = dis[i][k] + dis[k][j];

  所以对于原图再跑一遍floyd。

  如果出现dis[i][k] + dis[k][j] < dis[i][j]的情况,则给出的邻接矩阵不是最短路,无解。

  对于三个点i,j,k,如果有dis[i][j] == dis[i][k] + dis[k][j],则(i,j)这条边一定可以舍去。

  因为如果其他的最短路径要用到(i,j)边的话,用(i,k)+(k,j)边替换也是可以的。

  所以在floyd中顺便统计下就可以了。

AC Code:

 #include <iostream>
#include <stdio.h>
#include <string.h>
#define MAX_N 105 using namespace std; int n,t,cas;
int dis[MAX_N][MAX_N];
bool vis[MAX_N][MAX_N]; void read()
{
cin>>n;
for(int i=;i<=n;i++)
{
for(int j=;j<=n;j++)
{
cin>>dis[i][j];
}
}
} int floyd()
{
memset(vis,false,sizeof(vis));
int cnt=n*(n-);
for(int k=;k<=n;k++)
{
for(int i=;i<=n;i++)
{
for(int j=;j<=n;j++)
{
if(i!=j && j!=k && i!=k)
{
if(dis[i][k]+dis[k][j]<dis[i][j]) return -;
if(dis[i][k]+dis[k][j]==dis[i][j] && !vis[i][j])
{
vis[i][j]=true;
cnt--;
}
}
}
}
}
return cnt;
} void work()
{
int ans=floyd();
cout<<"Case "<<cas<<": ";
if(ans==-) cout<<"impossible"<<endl;
else cout<<ans<<endl;
} int main()
{
cin>>t;
for(cas=;cas<=t;cas++)
{
read();
work();
}
}

最新文章

  1. C# WinForm 中英文实现, 国际化实现的简单方法
  2. lua高阶用法 OO的实现
  3. JS逻辑运算符&amp;&amp;与||的短路运算
  4. kafka的一些认识
  5. 面试准备 - HashTable 的C#实现 开放地址法
  6. OpenResty(nginx+lua) 入门
  7. hbase常用命令总结
  8. Lucene/ElasticSearch 学习系列 (1) 为什么学,学什么,怎么学
  9. javascript实现经纬度与地址的互转
  10. 小白日记20:kali渗透测试之后渗透测试阶段(一)--上传工具
  11. preg_replace的用法
  12. Visual C++ 6.0 解决win 8.1不兼容的问题。--技术宅从来不妥协
  13. commons-logging 结合 log4j, 初始化生命周期 初探
  14. JavaScript OOP 之 this指向
  15. 算法(第四版)C# 习题题解——2.3
  16. nvidia-smi failed because it couldn&#39;t communicate with the nvidia driver
  17. Unable to preventDefault inside passive event listener due to target being treated as passive?
  18. P4546 [THUWC2017]在美妙的数学王国中畅游
  19. IE盒模型与W3C盒模型区别
  20. hdu1024 Max Sum Plus Plus 滚动dp

热门文章

  1. asp.net web.config配置节说明
  2. Log4Net.Config配置信息《转》
  3. C语言中的main函数以及main函数是如何被调用的
  4. MIC性能优化策略
  5. html5小趣味知识点系列(一)autofocus
  6. windows下php配置redis
  7. Nodejs通过thrift访问Java服务
  8. TP框架---thinkphp中ajax分页
  9. 序列DP(输出有要求)
  10. 电路分析二-------基尔霍夫定律KCL和KVL