HDU3072 Intelligence System
有个中文版的题面...和原题稍有不同
/*
Description
“这一切都是命运石之门的选择。”
试图研制时间机器的机关SERN截获了中二科学家伦太郎发往过去的一条短信,并由此得知了伦太郎制作出了电话微波炉(仮)。
为了掌握时间机器的技术,SERN总部必须尽快将这个消息通过地下秘密通讯网络,传达到所有分部。
SERN共有N个部门(总部编号为0),通讯网络有M条单向通讯线路,每条线路有一个固定的通讯花费Ci。
为了保密,消息的传递只能按照固定的方式进行:从一个已知消息的部门向另一个与它有线路的部门传递(可能存在多条通信线路)。我们定义总费用为所有部门传递消息的费用和。
幸运的是,如果两个部门可以直接或间接地相互传递消息(即能按照上述方法将信息由X传递到Y,同时能由Y传递到X),我们就可以忽略它们之间的花费。
由于资金问题(预算都花在粒子对撞机上了),SERN总部的工程师希望知道,达到目标的最小花费是多少。 Input
多组数据,文件以2个0结尾。
每组数据第一行,一个整数N,表示有N个包括总部的部门(从0开始编号)。然后是一个整数M,表示有M条单向通讯线路。
接下来M行,每行三个整数,Xi,Yi,Ci,表示第i条线路从Xi连向Yi,花费为Ci。 Output
每组数据一行,一个整数表示达到目标的最小花费。 Sample Input
3 3
0 1 100
1 2 50
0 2 100
3 3
0 1 100
1 2 50
2 1 100
2 2
0 1 50
0 1 100
0 0 Sample Output
150
100
50
【样例解释】
第一组数据:总部把消息传给分部1,分部1再传给分部2.总费用:100+50=150.
第二组数据:总部把消息传给分部1,由于分部1和分部2可以互相传递消息,所以分部1可以无费用把消息传给2.总费用:100+0=100.
第三组数据:总部把消息传给分部1,最小费用为50.总费用:50. Data Constraint
对于10%的数据,保证M=N-1
对于另30%的数据,N ≤ 20 ,M ≤ 20
对于100%的数据,N ≤ 50000 ,M ≤ 10^5 ,Ci ≤ 10^5 ,数据组数 ≤ 5
数据保证一定可以将信息传递到所有部门。
中文题面
初看此题,大概是要在一个有向图里找到从固定点出发遍历每个节点的最小花费
emm...瞬间想到最小生成树,prim大概是有的
"如果两个部门可以直接或间接地相互传递消息,我们就可以忽略它们之间的花费。"
也就是只要有节点形成了环,那么这些节点间通信不要钱...
这不就tarjan缩点过后prim就好了吗...
code了1h,搞出来了,结果发现样例都过不了
原因是prim在有向图里没办法处理权值相同的边!(@最小树形图)
又想了想,缩点后是个DAG图,又保证起始点可以走到所有点,所以对于每一个点,不管它选哪一个入度,都不会影响连通性
那就贪心,对于除起始点的每一个点,取它入度的最小值,然后把所有点加起来就是答案了
这玩意还比prim好写很多
上代码咯
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
#include<ctime>
#include<cstdlib>
#include<queue>
using namespace std;
const int INF=pow(,)-; struct star {//存边
int u,v,w;
};
struct Map {//图
int ptn,edn;
star edge[];//链式前向星存储
int last[],next[];
void mapinit(int pig){//初始化
ptn=pig;
edn=;
}
void addedge(int u,int v,int w) {//加边函数
edn++;
edge[edn]=(star){u,v,w};
}
void starinit() {//前向星初始化
for(int i=;i<=ptn;i++) last[i]=-;
for(int i=;i<=edn;i++){
int flag=edge[i].u;
next[i]=last[flag];
last[flag]=i;
}
}
}A,B;//A是缩点前的图,B是缩点后的图
int bel[];//A中点对应B中哪一个点
int Bn; int tim;
int dfn[],low[];
int stack[],top;
int isput[],t_vis[];
void tarjan(int node){//tarjan缩点
tim++;
dfn[node]=tim;
low[node]=tim;
isput[node]=;
t_vis[node]=;
stack[top]=node;
top++;
for(int i=A.last[node];i!=-;i=A.next[i]){
int to=A.edge[i].v;
if(isput[to]==){
low[node]=min(low[node],dfn[to]);
}else if(t_vis[to]==){
}else{
tarjan(to);
low[node]=min(low[node],low[to]);
}
}
if(dfn[node]==low[node]){
Bn++;
for(;;){
top--;
bel[stack[top]]=Bn;
isput[stack[top]]=;
if(stack[top]==node||top==) break;
}
}
}
int ans;
int mn[]; int An,Am;
int main() {
for(;;){
if(scanf("%d",&An)==EOF)break;
//input
scanf("%d",&Am);
A.mapinit(An);
for(int i=;i<=Am;i++){
int u,v,w;
scanf("%d%d%d",&u,&v,&w);
u++;v++;
A.addedge(u,v,w);
}
A.starinit();
//tarjan
for(int i=;i<=An;i++) {dfn[i]=;low[i]=;t_vis[i]=;}
tim=;
top=;
Bn=;
tarjan();
//getB
B.mapinit(Bn);
for(int i=;i<=A.edn;i++){//用A图的强连通分量建B图
int u=bel[A.edge[i].u],v=bel[A.edge[i].v],w=A.edge[i].w;
if(u==v) continue;
B.addedge(u,v,w);
}
B.starinit();
ans=;
//getans
for(int i=;i<=B.ptn;i++) mn[i]=INF;
for(int i=;i<=B.edn;i++){//贪心
int to=B.edge[i].v;
mn[to]=min(mn[to],B.edge[i].w);
}
mn[bel[]]=;//起始点
for(int i=;i<=B.ptn;i++){
ans+=mn[i];
}
printf("%d\n",ans);
}
return ;
}
HDU3072 Intelligence System的更多相关文章
- hdu3072 Intelligence System (最小树形图?)
题意:给一个有向图,问要从0号点能到达所有点所需要经过路径的最小权值和是多少,然而,若两点强联通,则这两点互相到达不需要花费.保证0号点能到达所有点 tarjan缩点以后直接取每个点入边中花费最小的即 ...
- [HDU3072]:Intelligence System(塔尖+贪心)
题目传送门 题目描述 “这一切都是命运石之门的选择.”试图研制时间机器的机关SERN截获了中二科学家伦太郎发往过去的一条短 信,并由此得知了伦太郎制作出了电话微波炉(仮).为了掌握时间机器的技术,SE ...
- HDU 3072 Intelligence System (强连通分量)
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdoj 3072 Intelligence System【求scc&&缩点】【求连通所有scc的最小花费】
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- Intelligence System
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- HDU 3072 Intelligence System(tarjan染色缩点+贪心+最小树形图)
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 3072 Intelligence System(Tarjan 求连通块间最小值)
Intelligence System Time Limit : 2000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) ...
- Intelligence System (hdu 3072 强联通缩点+贪心)
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- HDU——3072 Intelligence System
Intelligence System Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
随机推荐
- 全基因组关联分析(GWAS)扫不出信号怎么办(文献解读)
假如你的GWAS结果出现如下图的时候,怎么办呢?GWAS没有如预期般的扫出完美的显著信号,也就没法继续发挥后续研究的套路了. 最近,nature发表了一篇文献“Common genetic varia ...
- Vue(一)安装
环境准备 这里我们就直接使用官方推荐的Vue CLI方式 CLI (@vue/cli) 是一个全局安装的 npm 包,提供了终端里的 vue 命令.它可以通过 vue create 快速创建一个新项目 ...
- Linux(1)-卸载挂载分区
> df -lh > fuser -m -v /dev/mapper/autovg-autolv > fuser -m -k -v /dev/mapper/autovg-autolv ...
- 使用AForge.NET Framework打开摄像头并截图 C#
videoDevices = new FilterInfoCollection(FilterCategory.VideoInputDevice); if (videoDevices.Count == ...
- Browserify模块化使用教程
Browserify模块化使用教程 创建项目结构 |-js |-dist //打包生成文件的目录 |-src //源码所在的目录 |-module1.js |-module2.js |-m ...
- cacti报警邮件的设置
众所周知,用Linux系统自带的sendmail发送邮件是有限制的,可能对有些邮箱无法正常发送,导致报警邮件不能够及时发送到,因此就可能会产生不必要的麻烦!对此,我们可以用其他方法来发送邮件,就是在c ...
- GIT-常规操作
本地安装git, 安装文件: Git客户端: 可百度搜索:GIT64位或GIT32位等关键字找到相应的版本进行下载. 本地地址:D:\20-git\Git-2.20.1-64-bit.exe 也可百度 ...
- NOI-OJ 1.13 ID:34 确定进制
整体思路 对于任意的p,q,r,可能使得p*q=r的最小进制应该是p,q,r三个数的所有数位中最大的数字+1,例如,6,9,42三个数中所有数位中最大的数字是9,故可能成立的最小进制是9+1,即10. ...
- MySQL的一些基本命令笔记(3)
指明外键: 1 :1 两个表中的主键都可以当成外键 1 :N 在 "多" 的实体表中新增加一个字段,该字段是 "一" 实体表的主键 M : N 拆成两个1 :N ...
- oracle数据库驱动(ojdbc)
第1部分 Q:为什么oralce的jdbc驱动,在maven上搜索到把pom配置复制到pom.xml里进行引用的时候会报错? ANS:虽然能在maven仓库里搜索到,但貌似不能用,原因是oracle是 ...