垃圾csdn,累感不爱!


题目链接:

http://codeforces.com/contest/667/problem/D

题意:

在有向图中找到四个点,使得这些点之间的最短距离之和最大。

分析:

最简单的Bellman求最短路复杂度太高。可以对每个点进行一次bfs,获得所有连通的点之间的最短距离。

点数最多3000,枚举中间两个点\(i,j\),对于点\(i\)考虑反向边的最远距离,对于点\(j\)考虑正向边的最远距离。

由于题目说点不同,所以对于每个点我们保存前三个远的点并枚举求得最远距离即可。这样枚举下来时间复杂度\(O(n^2)\)。

代码:

#include<cstdio>
#include<cstring>
#include<iostream>
#include<vector>
#include<queue>
#include<algorithm>
using namespace std;
const int maxn = 3e3 + 5, oo = 0x3f3f3f3f;
int d[maxn][maxn];
int n, m;
typedef pair<int, int>p;
vector<p>zz[maxn], rzz[maxn];
vector<int>G[maxn];
void bfs()
{
for(int i = 1; i <= n; i++){
queue<int>q;
q.push(i);
while(!q.empty()){
int u = q.front(); q.pop();
for(int j = 0; j <G[u].size(); j++){
int w = G[u][j];
if(d[i][w] != oo) continue;
d[i][w] = d[i][u] + 1;
q.push(w);
}
}
}
}
int main (void)
{
scanf("%d%d", &n, &m);
memset(d, 0x3f, sizeof(d));
for(int i = 1; i <= n; i++) d[i][i] = 0;
int u, v;
for(int i = 0; i < m; i++){
scanf("%d%d", &u, &v);
G[u].push_back(v);
}
bfs();
for(int i = 1; i <= n; i++){
for(int j = 1; j <= n; j++){
if(i == j) continue;
if(d[i][j] != oo) zz[i].push_back(p(d[i][j], j));
if(d[j][i] != oo) rzz[i].push_back(p(d[j][i], j));
}
sort(zz[i].begin(), zz[i].end());
sort(rzz[i].begin(), rzz[i].end());
}
int r1, r2, r3, r4;
int maxx = 0;
int res;
for(int i = 1; i <= n; i++){
int a = zz[i].size();
for(int j = 1; j <= n; j++){
int b = rzz[j].size();
if(i == j || d[j][i] == oo) continue;
for(int k= a - 1; k >= a - 3 && k >= 0; k--){
if(zz[i][k].second == j) continue;
for(int y = b - 1; y >= b - 3 && y >= 0; y--){
if(zz[i][k].second == rzz[j][y].second) continue;
if(rzz[j][y].second == i) continue;
res = d[j][i] + rzz[j][y].first + zz[i][k].first;
if(res > maxx){
maxx = res;
r1 = rzz[j][y].second, r2 = j, r3 = i, r4 = zz[i][k].second;
}
}
}
}
}
//cout<<maxx<<endl;
printf("%d %d %d %d\n", r1, r2, r3, r4);
}

最新文章

  1. node.js之path
  2. 二项分布 多项分布 伽马函数 Beta分布
  3. html 绑定
  4. ramBufferSizeMB
  5. 14)Java中Assert
  6. gtest编译小结(ubuntu 12.10 , gtest 1.6.0)
  7. Java虚拟机体系结构深入研究总结
  8. AC自动机(模板)
  9. 201521123070 《JAVA程序设计》第14周学习总结
  10. if;脚本中退出语句:exit 数字,用$?查时为exit设置的数字,此数字为程序执行完后的返回数据,可以通过此方法自动设定
  11. JAVA基础-File类
  12. Linux:alias永久生效
  13. ORACLE之TO_DATE (转载)
  14. Hibernate 再接触 组件映射
  15. Linux 中 awk命令应用
  16. 转:vue-router 2.0 常用基础知识点之router.push()
  17. sql 计算两个经纬度点之间的距离
  18. nginx AIO机制与sendfile机制
  19. MySQL主从复制与读写分离[修改]
  20. linux 查看文件夹文件大小数目等信息

热门文章

  1. 当然,perl等脚本服务器是一般默认安装了,你入侵了一台主机,总不能先装配 Java 环境然后再开干吧?
  2. PAT (Advanced Level) Practise - 1096. Consecutive Factors (20)
  3. java在线聊天项目 实现基本聊天功能后补充的其他功能详细需求分析 及所需要掌握的Java知识基础 SWT的激活方法,swt开发包下载,及破解激活码
  4. Spring入门Ioc、DI笔记
  5. Linux用户身份(命令详解与补正)
  6. log4j日志输出到文件的配置
  7. CVS update常用技巧
  8. Python 基本数据类型 (一) - 整数
  9. wp8 longlistselector 动态加载datatemplate
  10. Matplotlib基础图形之散点图