B. 通讯

 
题目类型:传统 评测方式:文本比较
 内存限制:256 MiB 时间限制:1000 ms 标准输入输出

题目描述

“这一切都是命运石之门的选择。”

试图研制时间机器的机关SERN截获了中二科学家伦太郎发往过去的一条短 信,并由此得知了伦太郎制作出了电话微波炉(仮)。

为了掌握时间机器的技术,SERN总部必须尽快将这个消息通过地下秘密通讯 网络,传达到所有分部。

SERN共有N个部门(总部编号为0),通讯网络有M条单向通讯线路,每条线 路有一个固定的通讯花费Ci。

为了保密,消息的传递只能按照固定的方式进行:从一个已知消息的部门向 另一个与它有线路的部门传递(可能存在多条通信线路)。我们定义总费用为所 有部门传递消息的费用和。

幸运的是,如果两个部门可以直接或间接地相互传递消息(即能按照上述方 法将信息由X传递到Y,同时能由Y传递到X),我们就可以忽略它们之间的花费。

由于资金问题(预算都花在粒子对撞机上了),SERN总部的工程师希望知道, 达到目标的最小花费是多少。

输入格式

多组数据,文件以2个0结尾。

每组数据第一行,一个整数N,表示有N个包括总部的部门(从0开始编号)。 然后是一个整数M,表示有M条单向通讯线路。

接下来M行,每行三个整数,Xi,Yi,Ci,表示第i条线路从Xi连向Yi,花费为 Ci。

输出格式

每组数据一行,一个整数表示达到目标的最小花费。

样例

样例输入

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

样例输出

150
100
50

数据范围与提示

样例解释

第一组数据:总部把消息传给分部1,分部1再传给分部2.总费用:100+50=150.

第二组数据:总部把消息传给分部1,由于分部1和分部2可以互相传递消息,所以分部1可以无费用把消息传给2.总费用:100+0=100.

第三组数据:总部把消息传给分部1,最小费用为50.总费用:50.

数据范围

对于10%的数据,保证M=N-1

对于另30%的数据,N ≤ 20 ,M ≤ 20

对于100%的数据,N ≤ 50000 ,M ≤ 10^5 ,Ci ≤ 10^5 ,

数据组数 ≤ 5
数据保证一定可以将信息传递到所有部门。

水题

tarjan缩点,贪心找每个点的最小入边即可(我用dfs实现,本质都是贪心)

我的tarjan+dfs(下面有天皇skyh的贪心找小边)

#include<iostream>
#include<cstdio>
#include<vector>
using namespace std;
int n,m,dfn[],low[],num,st[],sp[],ins[],mi[],v[],cnt;
struct node{
int ver,len;
};
vector<node>to[],son[];
void tarjan(int x){
dfn[x]=low[x]=++num;
st[++st[]]=x;
ins[x]=;
//sort(to[x].begin(),to[x].end(),cmp);
for(int i=;i<to[x].size();i++){
node w=to[x][i];
if(!dfn[w.ver]){
tarjan(w.ver);
low[x]=min(low[x],low[w.ver]);
}
else if(ins[w.ver]) low[x]=min(low[x],dfn[w.ver]);
}
if(low[x]==dfn[x]){
cnt++;
int y;
do{
y=st[st[]--];
ins[y]=;
sp[y]=cnt;
}while(y!=x); }
}
long long dfs(int x){
v[x]=;
long long cet=;
//sort(son[x].begin(),son[x].end(),cmp);
// cout<<x<<" "<<son[x].size()<<endl;
for(int i=;i<son[x].size();i++){
node w=son[x][i];
//cout<<w.ver<<" "<<w.len<<endl;
if(v[w.ver]){
if(mi[w.ver]>w.len){
cet-=(mi[w.ver]-w.len);
mi[w.ver]=w.len;
}
continue;
}
cet+=dfs(w.ver);
cet+=w.len; mi[w.ver]=w.len;
}
///cout<<cet<<endl;
return cet; }
int main(){
scanf("%d%d",&n,&m);
while(n!=||m!=){
int x;
for(int i=;i<=m;i++){
node w;
scanf("%d%d%d",&x,&w.ver,&w.len);
w.ver++;
to[x+].push_back(w);
}
// for(int i=1;i<=n;i++) cout<<i<<" "<<to[i].size()<<endl;
for(int i=;i<=n;i++)
if(!dfn[i]) tarjan(i);
//for(int i=1;i<=n;i++) cout<<i<<" "<<to[i].size()<<endl;
for(int i=;i<=n;i++){
//cout<<i<<" "<<sp[i]<<" "<<to[i].size()<<endl;
for(int j=;j<to[i].size();j++){
node w=to[i][j];
if(sp[i]!=sp[w.ver]){
w.ver=sp[w.ver];
son[sp[i]].push_back(w);
}
}
}
/*for(int i=1;i<=cnt;i++){
cout<<i<<" "<<son[i].size()<<endl;
for(int j=0;j<son[i].size();j++){
printf("%d %d %d\n",i,son[i][j].ver,son[i][j].len);
}
}*/
long long ans=dfs(sp[]);
printf("%lld\n",ans);
for(int i=;i<=n;i++){
dfn[i]=low[i]=v[i]=sp[i]=mi[i]=v[i]=;
to[i].clear();
son[i].clear();
num=;
cnt=;
}
scanf("%d%d",&n,&m);
} }

——————————————————————————————————————————————————————————————————————————————

天皇skyh的贪心找小边

#include<iostream>
#include<cstdio>
#include<cstring>
#define db(x) cerr<<#x<<"="<<x<<endl
#define cl(x) memset(x,0,sizeof(x))
using namespace std;
const int N=,M=;
int n,m,scc;
int tot,head[N],to[M],nxt[M],w[M];
int top,stack[N],dfn[N],low[N],num,bl[N];
bool instack[N];
int imin[N];
void tarjan(int x)
{
dfn[x]=low[x]=++num;
stack[++top]=x; instack[x]=;
for(int i=head[x];i;i=nxt[i])
{
int y=to[i];
if(!dfn[y])
{
tarjan(y);
low[x]=min(low[x],low[y]);
}
else if(instack[y]) low[x]=min(low[x],dfn[y]);
}
if(dfn[x]==low[x])
{
++scc; int y;
do{
y=stack[top--];
bl[y]=scc;
instack[y]=;
}while(y!=x);
}
}
int main()
{
while(scanf("%d%d",&n,&m)==&&(n||m))
{
cl(dfn); cl(head);
memset(imin,0x3f,sizeof(imin));
tot=; top=; num=; scc=;
for(int i=,a,b,d;i<=m;i++)
{
scanf("%d%d%d",&a,&b,&d);
a++; b++;
to[++tot]=b; w[tot]=d;
nxt[tot]=head[a]; head[a]=tot;
}
tarjan();
//db(scc);
for(int i=;i<=n;i++)
for(int j=head[i];j;j=nxt[j])
{
int y=to[j];
if(bl[i]==bl[y]) continue;
imin[bl[y]]=min(imin[bl[y]],w[j]);
}
long long ans=;
for(int i=;i<=scc;i++)
if(imin[i]<=)
ans+=imin[i];
printf("%lld\n",ans);
}
return ;
}

通讯(tarjan缩点)(20190716NOIP模拟测试4)的更多相关文章

  1. NOIP模拟测试2-5

    该补一下以前挖的坑了 先总结一下 第二次 T1 搜索+剪枝 #include<cstdio> #include<iostream> #define ll long long u ...

  2. 20190716NOIP模拟赛T2 通讯(tarjan缩点+贪心)

    题目描述 “这一切都是命运石之门的选择.” 试图研制时间机器的机关SERN截获了中二科学家伦太郎发往过去的一条短 信,并由此得知了伦太郎制作出了电话微波炉(仮). 为了掌握时间机器的技术,SERN总部 ...

  3. 【模拟7.16】通讯(tarjan缩点加拓扑排序)

    这题确实水,纯板子,考试意外出错,只拿了暴力分QAQ tarjan缩点加上拓扑排序,注意这里求最短路径时不能用最小生成树 因为是单向边,不然就可能不是一个联通图了.... 1 #include< ...

  4. 7.16 NOIP模拟测试4 礼物+通讯+奇袭

    T1 礼物 题目大意:n个物品,每次有pi的概率买到,可以重复买,也可以什么都没买到,但算一次购买,问把所有东西都买到的期望次数.对于10%的数据,N = 1;对于30%的数据,N ≤ 5;对于100 ...

  5. 【2019.7.26 NOIP模拟赛 T3】化学反应(reaction)(线段树优化建图+Tarjan缩点+拓扑排序)

    题意转化 考虑我们对于每一对激活关系建一条有向边,则对于每一个点,其答案就是其所能到达的点数. 于是,这个问题就被我们搬到了图上,成了一个图论题. 优化建图 考虑我们每次需要将一个区间向一个区间连边. ...

  6. 2019.8.9 NOIP模拟测试15 反思总结

    日常爆炸,考得一次比一次差XD 可能还是被身体拖慢了学习的进度吧,虽然按理来说没有影响.大家听的我也听过,大家学的我也没有缺勤多少次. 那么果然还是能力问题吗……? 虽然不愿意承认,但显然就是这样.对 ...

  7. NOIP模拟测试19「count·dinner·chess」

    反思: 我考得最炸的一次 怎么说呢?简单的两个题0分,稍难(我还不敢说难,肯定又有人喷我)42分 前10分钟看T1,不会,觉得不可做,完全不可做,把它跳了 最后10分钟看T1,发现一个有点用的性质,仍 ...

  8. [Usaco2015 Jan]Grass Cownoisseur Tarjan缩点+SPFA

    考试的时候忘了缩点,人为dfs模拟缩点,没想到竟然跑了30分,RB爆发... 边是可以重复走的,所以在同一个强连通分量里,无论从那个点进入从哪个点出,所有的点一定能被一条路走到. 要使用缩点. 然后我 ...

  9. BZOJ1823[JSOI2010]满汉全席——2-SAT+tarjan缩点

    题目描述 满汉全席是中国最丰盛的宴客菜肴,有许多种不同的材料透过满族或是汉族的料理方式,呈现在數量繁多的菜色之中.由于菜色众多而繁杂,只有极少數博学多闻技艺高超的厨师能够做出满汉全席,而能够烹饪出经过 ...

随机推荐

  1. Win8 Metro(C#)数字图像处理--2.54迭代法图像二值化

    原文:Win8 Metro(C#)数字图像处理--2.54迭代法图像二值化  [函数名称]   迭代法图像二值化      int IterativeThSegment(WriteableBitm ...

  2. CentOS 7使用yum快速搭建LAMP环境

    1.安装Apache [root@localhost ~]# yum -y install httpd # 开机自启动 [root@localhost ~]# chkconfig httpd on # ...

  3. ASP如何实现注册后发送激活邮件?

    <% Sub Sendemail(title,content,email) Set jmail = Server.CreateObject("JMAIL.Message") ...

  4. ASP.NET MVC视图

    前言 视图即是用户与Web应用程序的接口,用户通常会看到视图,然后在视图上进行交互,Web应用程序的视图通常是HTML格式. 首先了解控制器选择返回哪个视图的问题.新建一个项目,浏览到/Home/Ab ...

  5. SpringMVC与uploadify结合进行上传

    uploadify是一个第三方js插件,支持多文件上传,拥有较为强大的上传功能 1.uploadify实现 下载其flash版本 http://www.uploadify.com/  解压后将其内容区 ...

  6. MSB3268 .Net 4.0工程 引用BCL错误

    Severity Code Description Project File Line Suppression StateWarning MSB3268 The primary reference & ...

  7. Socket2实现tcp端口扫描

    主要的界面如下: 主要代码如下: //对于每一个线程,传过去的参数 typedef struct ThreadParamStruct { CString strIP; //要扫描的IP地址 UINT ...

  8. spring boot之actuator简介

    当我们的开发工作进入尾声,部署上线之后,对于一个程序而言,可能才刚刚开始,对程序的运行情况的监控要伴随着整个生命周期. 如果这个工作由程序员自己来开发,也未尝不可,但本着不重复制造轮子的思想,我们尽量 ...

  9. 前端视频转码flv->swf

    在项目中本来是要用<video>标签插入视频,但此标签不支持flv格式,上网也是搜了很多,试了很久才成功(其他格式不是很清楚你们可以尝试看看) 所用技术 flach (Flvplayer. ...

  10. UTM (Urchin Tracking Module) codes

    UTM Codes are a great way to see the results of your offline marketing In today’s day and age, we ar ...