题目链接:http://poj.org/problem?id=1511

Description

In the age of television, not many people attend theater performances. Antique Comedians of Malidinesia are aware of this fact. They want to propagate theater and, most of all, Antique Comedies. They have printed invitation cards with all the necessary information and with the programme. A lot of students were hired to distribute these invitations among the people. Each student volunteer has assigned exactly one bus stop and he or she stays there the whole day and gives invitation to people travelling by bus. A special course was taken where students learned how to influence people and what is the difference between influencing and robbery.

The transport system is very special: all lines are unidirectional
and connect exactly two stops. Buses leave the originating stop with
passangers each half an hour. After reaching the destination stop they
return empty to the originating stop, where they wait until the next
full half an hour, e.g. X:00 or X:30, where 'X' denotes the hour. The
fee for transport between two stops is given by special tables and is
payable on the spot. The lines are planned in such a way, that each
round trip (i.e. a journey starting and finishing at the same stop)
passes through a Central Checkpoint Stop (CCS) where each passenger has
to pass a thorough check including body scan.

All the ACM student members leave the CCS each morning. Each
volunteer is to move to one predetermined stop to invite passengers.
There are as many volunteers as stops. At the end of the day, all
students travel back to CCS. You are to write a computer program that
helps ACM to minimize the amount of money to pay every day for the
transport of their employees.

Input

The
input consists of N cases. The first line of the input contains only
positive integer N. Then follow the cases. Each case begins with a line
containing exactly two integers P and Q, 1 <= P,Q <= 1000000. P is
the number of stops including CCS and Q the number of bus lines. Then
there are Q lines, each describing one bus line. Each of the lines
contains exactly three numbers - the originating stop, the destination
stop and the price. The CCS is designated by number 1. Prices are
positive integers the sum of which is smaller than 1000000000. You can
also assume it is always possible to get from any stop to any other
stop.

Output

For
each case, print one line containing the minimum amount of money to be
paid each day by ACM for the travel costs of its volunteers.

Sample Input

2
2 2
1 2 13
2 1 33
4 6
1 2 10
2 1 60
1 3 20
3 4 10
2 4 5
4 1 50

Sample Output

46
210 题目大意:给定一个有向图,问从起点到每一个点一个来回共需要多少时间
解题思路:将有向线段的起点和终点互换就可以得到任意点到起点的最短路了,由于数据量太大,需要用spfa,同时用cin也会超时。本来还想写一发dfs的,发现会爆栈,就只贴了bfs的码
 #include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<map>
#include<cstdio>
#include<queue> using namespace std; const int LEN = ;
const int INF = 0x3f3f3f3f; struct Edge{
int to, next;
long long val;
}edge[][LEN]; int h[][LEN], cnt1, cnt2;
int p, q;
long long dis[LEN];
bool vis[LEN]; void spfa_bfs( int cnt ){
queue<int> Q;
memset( dis, INF, LEN * sizeof( long long ) );
memset( vis, false, LEN * sizeof( bool ) ); dis[] = ;
Q.push( );
vis[] = true; while( !Q.empty() ){
int x;
x = Q.front(); Q.pop(); vis[x] = false; for( int k = h[cnt][x]; k!= ; k = edge[cnt][k].next ){
int y = edge[cnt][k].to;
if( dis[x] + edge[cnt][k].val < dis[y] ){
dis[y] = dis[x] + edge[cnt][k].val;
if( !vis[y] ){
vis[y] = true;
Q.push( y );
}
}
}
}
} int main(){
int n;
scanf( "%d", &n );
while( n-- ){
cnt1 = cnt2 = ;
scanf( "%d%d", &p, &q );
int beg, end;
long long val;
memset( h, , sizeof( h ) );
for( int i = ; i < q; i++ ){
scanf( "%d%d%lld", &beg, &end, &val );
edge[][cnt1].to = end;
edge[][cnt1].val = val;
edge[][cnt1].next = h[][beg];
h[][beg] = cnt1++; edge[][cnt2].to = beg;
edge[][cnt2].val = val;
edge[][cnt2].next = h[][end];
h[][end] = cnt2++;
} long long ans = ;
spfa_bfs( );
for( int i = ; i <= p; i++ ) ans += dis[i];
spfa_bfs( );
for( int i = ; i <= p; i++ ) ans += dis[i]; cout << ans << endl;
} return ;
}

POJ-1511 Invitation Cards( 最短路,spfa )的更多相关文章

  1. POJ 1511 Invitation Cards(Dijkstra(优先队列)+SPFA(邻接表优化))

    题目链接:http://poj.org/problem?id=1511 题目大意:给你n个点,m条边(1<=n<=m<=1e6),每条边长度不超过1e9.问你从起点到各个点以及从各个 ...

  2. POJ 1511 Invitation Cards / UVA 721 Invitation Cards / SPOJ Invitation / UVAlive Invitation Cards / SCU 1132 Invitation Cards / ZOJ 2008 Invitation Cards / HDU 1535 (图论,最短路径)

    POJ 1511 Invitation Cards / UVA 721 Invitation Cards / SPOJ Invitation / UVAlive Invitation Cards / ...

  3. POJ1511 Invitation Cards —— 最短路spfa

    题目链接:http://poj.org/problem?id=1511 Invitation Cards Time Limit: 8000MS   Memory Limit: 262144K Tota ...

  4. POJ 1511 Invitation Cards (最短路spfa)

    Invitation Cards 题目链接: http://acm.hust.edu.cn/vjudge/contest/122685#problem/J Description In the age ...

  5. POJ 1511 Invitation Cards (spfa的邻接表)

    Invitation Cards Time Limit : 16000/8000ms (Java/Other)   Memory Limit : 524288/262144K (Java/Other) ...

  6. poj 1511 Invitation Cards(最短路中等题)

    In the age of television, not many people attend theater performances. Antique Comedians of Malidine ...

  7. POJ 1511 Invitation Cards(单源最短路,优先队列优化的Dijkstra)

    Invitation Cards Time Limit: 8000MS   Memory Limit: 262144K Total Submissions: 16178   Accepted: 526 ...

  8. poj 1511 Invitation Cards (最短路)

    Invitation Cards Time Limit: 8000MS   Memory Limit: 262144K Total Submissions: 33435   Accepted: 111 ...

  9. Poj 1511 Invitation Cards(spfa)

    Invitation Cards Time Limit: 8000MS Memory Limit: 262144K Total Submissions: 24460 Accepted: 8091 De ...

  10. (简单) POJ 1511 Invitation Cards,SPFA。

    Description In the age of television, not many people attend theater performances. Antique Comedians ...

随机推荐

  1. Python—三目运算

    Python 可通过 if 语句来实现三目运算的功能,因此可以近似地把这种 if 语句当成三目运算符.作为三目运算符的 if 语句的语法格式如下: (True_statements) if (expr ...

  2. Kubernetes容器集群管理环境 - 完整部署(上篇)

    Kubernetes(通常称为"K8S")是Google开源的容器集群管理系统.其设计目标是在主机集群之间提供一个能够自动化部署.可拓展.应用容器可运营的平台.Kubernetes ...

  3. Python学习系列(三)Python 入门语法规则1

    一.注释 ''' 多行注释 ''' #单行注释 '''    #example1.1 测试程序  时间:4/17/2017 i1=input("请输入用户名:") i2=input ...

  4. [Spring cloud 一步步实现广告系统] 14. 全量索引代码实现

    上一节我们实现了索引基本操作的类以及索引缓存工具类,本小节我们开始实现加载全量索引数据,在加载全量索引数据之前,我们需要先将数据库中的表数据导出到一份文件中.Let's code. 1.首先定义一个常 ...

  5. Codeforces Round #575 (Div. 3)

    本蒟蒻已经掉到灰名了(菜到落泪),希望这次打完能重回绿名吧...... 这次赛中A了三题 下面是本蒟蒻的题解 A.Three Piles of Candies 这题没啥好说的,相加除2就完事了 #in ...

  6. spring cloud stream 经验总结

    ---恢复内容开始--- 基本概念 spring: cloud: stream: kafka: binder: brokers: cloudTest:19092 zk-nodes: cloudTest ...

  7. 理解MySQL(一)--MySQL介绍

    一.Mysql逻辑架构: 1. 第一层:服务器层的服务,连接\线程处理. 2. 第二层:查询执行引擎,MySQL的核心服务功能,包括查询解析.分析.优化和缓存,所有跨存储引擎的功能都在这一层实现. 3 ...

  8. Android 打包时 Keep 住某些方法或类

    # ${android_sdk}/tools/proguard/proguard-android.txt # Understand the @Keep support annotation. -kee ...

  9. spring架构解析--入门一

    Spring 框架中的核心组件只有三个:Core.Context 和 Beans.它们构建起了整个 Spring 的骨骼架构.简单理解: spring core是工具,context是环境,而bean ...

  10. 8.7 day28 网络编程 socket套接字 半连接池 通信循环 粘包问题 struct模块

    前置知识:不同计算机程序之间的数据传输 应用程序中的数据都是从程序所在计算机内存中读取的. 内存中的数据是从硬盘读取或者网络传输过来的 不同计算机程序数据传输需要经过七层协议物理连接介质才能到达目标程 ...