2016huasacm暑假集训训练三 D - Invitation Cards
题目链接:https://vjudge.net/contest/123674#problem/D
题意:一张个向图,求从点1开始到其他各点的最短路权值和加上从其他各点到点1的最短路权值和 首先注意的是这是一个有向图,既要求1到所有的点的距离又要求其他所有点到1的距离,由于只学过spfa算法,就又用了spfa算法,求1到其他点的距离比较好求,但其他点到1的距离就不太好求了,我用到了图的转置,就是把所有的边的方向都反向,给建立一个新的图,这样1以外的点到1的距离就是1到1以外的点的距离;
用习惯了Java还真不习惯c++,特别是看到指针就烦,但Java这时间也真吓人的,
AC代码: time: 21282ms 好可怕!
import java.util.*;
import java.io.*; public class Main {
public static Ver[] array1;
public static Ver[] array2;
public static int[] head1;
public static int[] head2;
public static int n;
public static long[] dis1;
public static long[] dis2;
public static boolean[] judge;
public static long Max = ;
public static long[] result;
public static int count; /**
* @param args
*/
public static void main(String[] args) throws IOException {
// TODO Auto-generated method stub
Scanner s = new Scanner(new BufferedInputStream(System.in));
int t = s.nextInt(); while (t-- > ) { n = s.nextInt();
int m = s.nextInt();
array1 = new Ver[];
array2 = new Ver[];
head1 = new int[n + ];
head2 = new int[n + ];
count = ;
for (int i = ; i < m; i++) { //建图
int a = s.nextInt();
int b = s.nextInt();
long c = s.nextLong();
array1[count] = new Ver(b, c); //正图
array1[count].next = head1[a];
head1[a] = count; array2[count] = new Ver(a, c); //反图
array2[count].next = head2[b];
head2[b] = count;
count++;
}
result = new long[n + ];
spfa1();
spfa2();
long ans = ;
for (int i = ; i <= n; i++) { //求和
ans += dis1[i] + dis2[i];
}
System.out.println(ans);
}
s.close();
} public static void spfa2(int a) { //反向图的spfa算法
dis2 = new long[n + ];
judge = new boolean[n + ];
for (int i = ; i < n + ; i++) {
dis2[i] = Max; }
LinkedList<Integer> queue = new LinkedList<Integer>();
judge[] = true;
dis2[] = ;
queue.add();
while (!queue.isEmpty()) {
int vpoll = queue.poll();
judge[vpoll] = false; int temp = head2[vpoll];
while (temp != ) {
if (relax2(vpoll, array2[temp].value, array2[temp].distance)) {
if (!judge[array2[temp].value]) {
judge[array2[temp].value] = true;
queue.add(array2[temp].value);
}
}
temp = array2[temp].next;
}
} } public static void spfa1(int a) { //正向图的spfa算法
dis1 = new long[n + ];
judge = new boolean[n + ];
for (int i = ; i < n + ; i++) {
dis1[i] = Max; }
LinkedList<Integer> queue1 = new LinkedList<Integer>();
judge[a] = true;
dis1[a] = ;
queue1.add(a);
while (!queue1.isEmpty()) {
int vpoll = queue1.poll();
judge[vpoll] = false; int temp = head1[vpoll];
while (temp != ) {
if (relax1(vpoll, array1[temp].value, array1[temp].distance)) {
if (!judge[array1[temp].value]) {
judge[array1[temp].value] = true;
queue1.add(array1[temp].value);
}
}
temp = array1[temp].next;
}
} } public static boolean relax1(int a, int b, long c) { if (dis1[a] + c < dis1[b]) {
dis1[b] = dis1[a] + c;
return true;
}
return false;
} public static boolean relax2(int a, int b, long c) { if (dis2[a] + c < dis2[b]) {
dis2[b] = dis2[a] + c;
return true;
}
return false;
} } class Ver { //图类
long distance;
int value;
int next; Ver(int value, long distance) {
this.value = value;
this.distance = distance;
}
}
2016huasacm暑假集训训练三 D - Invitation Cards的更多相关文章
- 2016huasacm暑假集训训练三 G - 还是畅通工程
题目链接:http://acm.hust.edu.cn/vjudge/contest/123674#problem/G 这题和上一道题差不多,还更简单点,直接用prim算法就行,直接贴AC代码: im ...
- 2016huasacm暑假集训训练三 F - Jungle Roads
题目链接:http://acm.hust.edu.cn/vjudge/contest/123674#problem/F 题意:在相通n个岛屿的所有桥都坏了,要重修,重修每一个桥所用的时间不同,求重修使 ...
- 2016huasacm暑假集训训练三 C - Til the Cows Come Home
题目链接:http://acm.hust.edu.cn/vjudge/contest/123674#problem/C N题目大意是有n个点,然后给出从a点到b点的距离,a和b是互相可以抵达的,则是无 ...
- 2016huasacm暑假集训训练三 B-Frogger
题目链接:http://acm.hust.edu.cn/vjudge/contest/123674#problem/B 题意:一只青蛙在湖中一颗石头上, 它想去有另一只青蛙的石头上,但是 湖里的水很脏 ...
- 2016huasacm暑假集训训练五 H - Coins
题目链接:http://acm.hust.edu.cn/vjudge/contest/126708#problem/H 题意:A有一大堆的硬币,他觉得太重了,想花掉硬币去坐的士:的士司机可以不找零,但 ...
- 2016huasacm暑假集训训练五 J - Max Sum
题目链接:http://acm.hust.edu.cn/vjudge/contest/126708#problem/J 题意:求一段子的连续最大和,只要每个数都大于0 那么就会一直增加,所以只要和0 ...
- 2016huasacm暑假集训训练五 G - 湫湫系列故事——减肥记I
题目链接:http://acm.hust.edu.cn/vjudge/contest/126708#problem/G 这是一个01背包的模板题 AC代码: #include<stdio.h&g ...
- 2016huasacm暑假集训训练五 F - Monkey Banana Problem
题目链接:http://acm.hust.edu.cn/vjudge/contest/126708#problem/F 题意:求至上而下一条路径的所经过的值得和最大值,这题比赛时就出了 但当时看不懂题 ...
- 2016huasacm暑假集训训练五 E - What Is Your Grade?
题目链接:http://acm.hust.edu.cn/vjudge/contest/126708#problem/E 题意:给做出的题目个数,5个的100分,4个的前n/2的同学95,后n/2的90 ...
随机推荐
- 腾讯WEB前端开发面试经历,一面二面HR面,面面不到!
[一面]~=110分钟 2014/09/24 11:20 星期三 进门静坐30分钟做题. 填空题+大题+问答题 >>填空题何时接触电脑 何时接触前端运算符 字符串处理 延 ...
- 多种JSON格式及遍历方式
/*数组*/ var arr = [["name", "value"], ["name1", "value1"]]; v ...
- 垂直居中display:table;
父级元素 display:table: 子元素 display:table-cell:vertical-align:middle:
- 听说awk语言也可以编写脚本
导读 从 awk 系列开始,我们都是在命令行或者脚本文件里写一些简短的 awk 命令和程序.然而 awk 和 shell 一样也是一个解释型语言.通过从开始到现在的一系列的学习,你现在能写可以执行的 ...
- Flask 吐血400错误
的确地址或者method不匹配,这个容易解决 在后端中取到了form中不存在的元素! 这个很麻烦,特别form里面的信息比较多时!这个需要一一排查.另外取元素时最好用 request.form.get ...
- Python全栈开发【基础一】
Python全栈开发[第一篇] 本节内容: Python 的种类 Python 的环境 Python 入门(解释器.编码.变量.input输入.if流程控制与缩进.while循环) if流程控制与wh ...
- java26
1:网络编程(理解) (1)网络编程:用Java语言实现计算机间数据的信息传递和资源共享 (2)网络编程模型 (3)网络编程的三要素 A:IP地址 ...
- jQuery treetable【表格多重折叠树功能及拖放表格子元素重新排列】
今天有个表格需求做到多重折叠子元素功能,仔细想了下实现原理, 1.在html中,把父子节点的关系写在自定义属性,但对于节点是否有孩子(hasChild),是否是最后一个节点(isLastOne),是否 ...
- 用Myeclipse,包名上有小红叉(表示错误),但是包中的类都是没有错误的+struts2继承ActionSupport时package前面出错
使用Eclipse 进行项目开发,在实现类中的方法前面如果添加@Override就提示“Multiple markers at this line”的错误,问题描述如下 应该是JDK版本的问题, 右击 ...
- node.js grunt文件压缩
对于前段来说,熟悉node的人其实还并不是太多,如果您想入门一门后端语言我建议还是从node入手最好. 我也是最近开始学习node,来谈谈近期对node的学习的心得. 提到node首先就是要安装一大堆 ...