bzoj1179(Atm)
---恢复内容开始---
1179: [Apio2009]Atm
Time Limit: 15 Sec Memory Limit: 162 MB
Description
Input
第一行包含两个整数N、M。N表示路口的个数,M表示道路条数。接下来M行,每行两个整数,这两个整数都在1到N之间,第i+1行的两个整数表示第i条道路的起点和终点的路口编号。接下来N行,每行一个整数,按顺序表示每个路口处的ATM机中的钱数。接下来一行包含两个整数S、P,S表示市中心的编号,也就是出发的路口。P表示酒吧数目。接下来的一行中有P个整数,表示P个有酒吧的路口的编号
Output
输出一个整数,表示Banditji从市中心开始到某个酒吧结束所能抢劫的最多的现金总数。
Sample Input
6 7
1 2
2 3
3 5
2 4
4 1
2 6
6 5
10
12
8
16
1
5
1 4
4
3
5
6
Sample Output
HINT
50%的输入保证N, M<=3000。所有的输入保证N, M<=500000。每个ATM机中可取的钱数为一个非负整数且不超过4000。输入数据保证你可以从市中心沿着Siruseri的单向的道路到达其中的至少一个酒吧。
这道题写了好久,终于写出来啦(哭。。。。。)
这道题思路大概是这样的,用adjacency list存完边后,先做一个tarjan并染色的预处理,然后把所有相同颜色的城市看成一个强连通分量,把这个强连通分量的颜色设置为新的地图编号为color的一个城市,然后将记录下来的原先的城市的道路,一一判断是否在新的map中是一座城市,若不是,那重新建立道路。(当然也得重新设置酒吧的位置)
最后跑一遍spfa求出每个酒吧的最大值即可(因为把强连通分量看成了一个城市了,所以不会再产生环)。
还是一样,贴代码(其实后来发现有一点可以省略不写的,就是重新设置好城市以后,把酒吧原来所在城市的的编号改成现在的就行,,还多开了一个array)
#include<cstdio> #include<cstring> #include<algorithm> ; using namespace std; struct node {int next,aim;}; node f[maxn],e[maxn]; int point,head[maxn],Low[maxn],stack[maxn],DFN[maxn],dep,top,cl[maxn],color,queue[maxn],n,m,newmoney[maxn]; bool vis[maxn],bar[maxn],newbar[maxn]; int x1[maxn],y1[maxn],money[maxn],start,t; long long ans,d[maxn]; void add(node *array,int x,int y) { point++; array[point].next=head[x]; head[x]=point; array[point].aim=y; } void tarjan(int x) { DFN[x]=Low[x]=++dep;//为节点u设定次序编号和Low初值 stack[++top]=x; vis[x]=true; //将节点u压入栈中 ;i=e[i].next)//枚举每一条边 if (!DFN[e[i].aim]) {//如果节点v未被访问过 tarjan(e[i].aim);//继续向下找 Low[x]=min(Low[x],Low[e[i].aim]); } else if (vis[e[i].aim])//如果节点v还在栈内 Low[x]=min(Low[x],DFN[e[i].aim]); if (DFN[x]==Low[x])//如果节点u是强连通分量的根 { vis[x]=)cl[x]=++color; while(stack[top]!=x) { cl[stack[top]]=color; vis[stack[top]]=false; top--; } top--; } } void spfa(int x) { ,tail=; queue[Head]=x; while(Head<tail) { ;i=f[i].next) { int u=f[i].aim; if(d[queue[Head]]+newmoney[u]>d[u]) { d[u]=d[queue[Head]]+newmoney[u]; if(!vis[u])queue[tail++]=u; vis[u]=true; } } vis[queue[Head]]=false; Head++; } } int main() { scanf("%d%d",&n,&m); ;i<=m;i++) { scanf("%d%d",&x1[i],&y1[i]); add(e,x1[i],y1[i]); } ;i<=n;i++) { scanf("%d",&money[i]); } scanf("%d",&start); scanf("%d",&t); ;i<=t;i++) { int l; scanf("%d",&l); bar[l]=true; } ;i<=n;i++) if(!DFN[i])tarjan(i); memset(head,,sizeof(head)); point=; ;i<=m;i++) { int p=cl[x1[i]],q=cl[y1[i]]; if(p!=q)add(f,p,q); } ;i<=n;i++) newmoney[cl[i]]+=money[i]; start=cl[start]; ;i<=n;i++) { if(bar[i]){ newbar[cl[i]]=true; } } memset(vis,,sizeof(vis)); d[start]=newmoney[start]; vis[start]=true; spfa(start); ;i<=color;i++) if(newbar[i])ans=max(ans,d[i]); printf("%lld",ans); ; }
---恢复内容结束---
bzoj1179(Atm)的更多相关文章
- Java测试笔记(ATM)
本次Java测试主要是做一个与ATM相似的系统,用文本文件来作为用户数据库,实现存款.取款.转账.修改密码.查询余额的功能.在做这次测试之前老师并没有讲解与Java相关的知识,所以这就需要我们自学Ja ...
- 网络基础篇之HDLC、PPP(原理)
一.广域网传输 之前讲解的都是关于局域网的数据传输,这次讲解的是广域网的传输. 广域网简称WAN,是一种跨越超大的.地域性的计算机网络集合.通常跨省.市.甚至一个国家.广域网包括很多子网,子网可以是局 ...
- 大话JS面向对象之开篇万物皆对象------(ATM取款机引发的深思)
一,总体概要 OO(面向对象)概念的提出是软件开发工程发展的一次革命,多年来我们借助它使得很多大型应用程序得以顺利实现.如果您还没有掌握并使用OO进行程序设计和开发,那么您无疑还停留在软件开发的石器时 ...
- Java 模拟ATM(修正)
ATM机的账户记录Account有账户的唯一性标识(11个长度的字符和数字的组合),用户的姓名,操作日期(Date),操作类型,账户密码(六位的数字,可以用0开头),当前的余额(可以为0). 模拟AT ...
- p3627&bzoj1179 抢掠计划(ATM)
传送门(洛谷) 传送门(bzoj) 题目 Siruseri 城中的道路都是单向的.不同的道路由路口连接.按照法律的规定, 在每个路口都设立了一个 Siruser i 银行的 ATM 取款机.令人奇怪的 ...
- MySQL银行ATM存取款机系统(需求分析)
银行ATM需求文档 一.E-R图形文 二.开发步骤 1.明确需求--数据库设计--编码实现功能--测试 2.绘制e-r图--绘制数据库模型图--使用三大方式规范数据库结构 三.开发思路 1. 模型图综 ...
- day26 作业(ATM第二版)
目录 start.py conf.settings.py core.src.py db.db_handler.py interface.bank_interface.py interface.shop ...
- ATM管理系统(三)
一.作业信息 博客班级 软件工程 作业要求 作业要求 作业目标 你理解的作业目标具体内容 学号 3180701218 二.题目要求 编写一个ATM管理系统,语言不限,要求应包括以下主要功能:(1)开户 ...
- linux 下用C实现 ATM 自动取款机功能 (进程间通信)
直接先上图: 项目需求: 主要分为两人大模块: 客户端 .进入时的功能开户.销户.登录.解锁 开户:输入姓名.身份证号.设置密码,如果开户成功,则服务器上保存一个账号信号(一个账号存一个文件,文件名建 ...
随机推荐
- java.lang.ClassCastException: android.view.AbsSavedState$1 cannot be cast to android.widget.ProgressBar$SavedState
java.lang.ClassCastException: android.view.AbsSavedState$1 cannot be cast to android.widget.Progress ...
- range()和xrange()区别
版本:Python2.7 1.先看帮助说明 (1)range()返回一个递增或递减的数字列表,列表的元素由三个参数决定 start 表示列表开始的值,默认为0 stop 表示列 ...
- vim安装不上
前阵子,刚安装Ubuntu时,安装vim的问题,现在些出来分享一下.apt-get install vim正在读取软件包列表... 完成正在分析软件包的依赖关系树正在读取状态信息... 完成有一些软件 ...
- 浅析jquery ui的datepicker组件
今天计划在博客上添加一个日历,方便用户查看日期.Google了一圈,最终决定使用jquery ui的datepicker部件实现.原因有三:Datepicker使用配置比较简洁,几行代码就可以得到一个 ...
- Appium(客户端版)解决每次运行Android,都安装Appium Setting和Unlock的方法
遇到的问题:使用的Appium界面的server进行启动,每次启动时都会安装Appium Setting和Unlock文件. 通过log可以看到安装路径如下: Appium Setting安装包路 ...
- C# basic
1. output Console.WriteLine("hello world"); 2. naming convention variable: start with lowe ...
- 第三节 Hello world --python初体验
祭旗--hello world 据说简单优雅.功能强大是python的魅力所在,这里看到简单了,优雅是什么样的,接下来的学习中慢慢体会吧! print ("Hello world" ...
- js高级选择器querySelector和querySelectorAll
querySelector 和 querySelectorAll 方法是 W3C Selectors API规范中定义的.他们的作用是根据 CSS 选择器规范,便捷定位文档中指定元素. 目前几乎主流浏 ...
- css 清除浮动最佳方法!
.clear:after{content:'\0020';display:block;height:0;clear:both} .clear{*zoom:1}
- Python编写邮件群发(qq邮箱)
#电子邮件操作 import poplib import smtplib from email.header import decode_header from email.mime.text imp ...