洛谷P1462-通往奥格玛瑞的路【日常图论,二分查找,最短路,SPAF】

前言

这道题感谢朋友的帮助,这里是他的博客地址:
http://blog.csdn.net/sugar_free_mint


题目

一个无向图,每个点和边都有一定的权值,要求从点1到点2在经过边的权值小于b的情况下经过点的最大权值尽量小

输入

4 4 8(4个点,4条边,要求边的权值小于8)
8(第一个点的权值)
5
6
10
2 1 2(2到1有条边权值为2)
2 4 1
1 3 4
3 4 3

输出

10


解题思路

先看看能否到达,不然输出AFK。然后如果可以,用二分法找最优答案


代码

#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
struct woc{int w,x,y,next;
};//邻接表
woc a[100001];
int n,m,b,xx,yy,ww,ls[10001],head,tail,cost[10001],t,state[10001];
bool v[10001];
long long f[10001];
bool spfa(int money)//如果经过点权值小于money,是否可以到达
{memset(f,127/3,sizeof(f));//初始化if (cost[1]>money) return false;//没用head=0;tail=1;v[1]=true;state[1]=1;f[1]=0;//初始化while (head!=tail){head++;//入队head=(head-1)%n+1;//循环队列t=ls[state[head]];//联通该点的一条边while (t!=0){if (f[a[t].x]+a[t].w<f[a[t].y]){f[a[t].y]=f[a[t].x]+a[t].w;if (!v[a[t].y] && cost[a[t].y]<=money)//看看点是否满足要求{tail++;//入队tail=(tail-1)%n+1;//循环队列state[tail]=a[t].y;v[a[t].y]=true;//标记}}t=a[t].next;//下一条边}v[state[head]]=false;//解封}if (f[n]<b) return true;return false;//返回结果
}
int main()
{int u=0,mid,l,r;scanf("%d%d%d",&n,&m,&b);for (int i=1;i<=n;i++){scanf("%d",&cost[i]);r=max(r,cost[i]);}l=max(cost[1],cost[n]);for (int i=1;i<=m;i++){scanf("%d%d%d",&xx,&yy,&ww);a[++u].x=xx;a[u].y=yy;a[u].w=ww;a[u].next=ls[xx];ls[xx]=u;a[++u].y=xx;a[u].x=yy;a[u].w=ww;a[u].next=ls[yy];ls[yy]=u;//无向图}if (!spfa(1000000001)) {printf("AFK");return 0;}//是否可以到达while (l<=r){mid=(l+r)/2;//二分if (spfa(mid)) r=mid-1;else l=mid+1;}printf("%d",l);//输出
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/324891.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

《此生未完成》痛句摘录(2)

System.out.print("今天开始继续读书摘录"); //不知道官方让不让我在博客里面记录 //如果不让的话我可能得转到别的上面记录 System.out.print("现在开始看《此生未完成》"); System.out.println("今天是第二天&#xff01;");他说他已经不再是二…

java正则表达式中的坑String.matches(regex)、Pattern.matches(regex, str)和Matcher.matches()

问题&#xff1a;程序会计算表达式的值 //将数值转换以K为单位 String value "10*1000*1000"; String regex"\\s*\\*\\s*1000\\s*"; boolean isMatch value .matches(regex); if(isMatch){value value.replaceFirst(regex,""); }else{String…

最全、最详细的配置jdk十步法!

求关注求转发大家好&#xff0c;我是雄雄。今天给大家分享的是 如何配置jdk &#xff0c;还记得我当年刚开始自学编程时&#xff0c;jdk配置了好几天才配置好&#xff0c;说来也是惭愧啊。并且配置成功的步骤我自己都不知道是啥&#xff0c;因为当时是东找一个方法&#xff0c;…

2018GDKOI——记录

前言 诶呀&#xff0c;这次GDKOI让我失去了AK的梦想 正题 感想 诶呀&#xff0c;题目真是难。反正不会&#xff0c;听课依旧半点不懂&#xff0c;所以我相信“暴力出奇迹”。 然后水总分120&#xff0c;两天都水得了60。 day1 题1 题目&#xff1a; 就是一个模拟地铁的&a…

interface关键字

接口的使用 1.接口使用interface来定义 2.Java中&#xff0c;接口和类是并列的两个结构 3.如何定义接口&#xff1a;定义接口中的成员3.1 JDK7及以前&#xff1a;只能定义全局常量和抽象方法>全局常量&#xff1a;public static final的.但是书写时&#xff0c;可以省略不写…

RabbitMQ系列教程之三:发布\/订阅(Publish\/Subscribe)

在前一个教程中&#xff0c;我们创建了一个工作队列。工作队列背后的假设是每个任务会被交付给一个【工人】。在这一部分我们将做一些完全不同的事情--我们将向多个【消费者】传递信息。这种模式被称为“发布/订阅”。 为了说明这种模式&#xff0c;我们将构建一个简单的日志…

路径使用场景

路径的使用场景 路径适用的范围&#xff1a;jsp页面中link script img a form 等 如果访问的是其他服务器中的项目文件只可以使用绝对路径 如果访问的是同一个服务器中的其他项目推荐使用根路径 如果访问的是同一个服务器中的同一个项目中的文件推荐使用相对base标签的路径 修改…

《此生未完成》痛句摘抄(3)

System.out.print("今天开始继续读书摘录"); //不知道官方让不让我在博客里面记录 //如果不让的话我可能得转到别的上面记录 System.out.print("现在开始看《此生未完成》"); System.out.println("今天是第三天&#xff01;");有时候常常会想到那…

【jzoj】2018.1.30NOIP普及组——模拟赛D组

_ 前言 写博客时间 2018/1/30 22:36。 感想&#xff1a;出数据的dalao我服&#xff01; 正题 题目1&#xff1a;二项式展开式&#xff08;jzoj2254&#xff09; 输入一个整数&#xff0c;求展开(ab)^n。展开方式为 (ab)^n?a^n?a^(n-1)b?a^(n-2)b^2…?b^n 其中” ? “…

开发人员也要懂点的测试知识

转载自 开发人员也要懂点的测试知识 本文来自于作者投稿&#xff0c;作者陈彩华&#xff0c;贝聊后端开发工程师。 最近参加了保利威测试总监李乐的《互联网测试姿势》为主题的分享交流会&#xff0c;收获颇丰&#xff0c;作为一个开放&#xff0c;秉承“不懂产品和测试的开…

Java8中接口的新特性

知识点1&#xff1a; 接口中定义的静态方法&#xff0c;只能通过接口来调用。 CompareA.method1(); 知识点2&#xff1a; 通过实现类的对象&#xff0c;可以调用接口中的默认方法。如果实现类重写了接口中的默认方法&#xff0c;调用时&#xff0c;仍然调用的是重写以后的方…

转发和重定向

需求说明 用户输入并提交登录信息 登录成功&#xff0c;跳转到success.jsp页面 登录失败&#xff0c;跳转回login.jsp页面 理解图 区别详解

实现自己的.NET Core配置Provider之Yaml

YAML是一种更适合人阅读的文件格式&#xff0c;很多大型的项目像Ruby on Rails都选择YAML作为配置文件的格式。如果项目的配置很少&#xff0c;用JSON或YAML没有多大差别。看看rails项目中的配置文件&#xff0c;如果用JSON写试试什么感受吧。 在《实现自己的.NET Core配置Pro…

信息时代与人工智能时代的教育变革

求关注求转发本文是雄雄的小课堂投稿的第 1 篇文章&#xff0c;作者&#xff1a;小溪时代发展迅速&#xff0c;学校的教育体系却没有很大的改变。比如现在的学生们还是学着几百年前的东西。试想一下&#xff0c;这是否真的适合我们这个时代&#xff0c;亦或真的需要改变了。教育…

【jzoj】2018.1.31 NOIP普及组——D组模拟赛

前言 今天题目比较水and我进了C组&#xff0c;不过太太太太太太太太太太太太太太太太绝望了QAQ。所以我也没有做C组的题。写完博客我就做O(∩_∩)O。 正题 题1&#xff1a;奇数统计&#xff08;jzoj1547&#xff09; 就是输入n个数&#xff0c;输出出现次数为奇数的一个数&a…

请求和响应向更多内容

1、请求更多方法 /*******[1]获得req对象中的头信息*(了解)*******************/Enumeration<String> headerNames req.getHeaderNames();while(headerNames.hasMoreElements()){String next headerNames.nextElement();System.out.println(next"-----"req.…

大数据Big Data

转载自 大数据Big Data 2012年本站曾对大数据预测&#xff1a;如果说2012年是大数据概念为人所知、引人瞩目、小试牛刀的一年&#xff0c;那么2013年大数据将会实现产品部署&#xff0c;早期投资获得回报&#xff0c;一小部分的产业被颠覆。到了2014年&#xff0c;各种大数据项…

RabbitMQ系列教程之四:路由(Routing)

在上一个教程中&#xff0c;我们构建了一个简单的日志系统&#xff0c;我们能够向许多消息接受者广播发送日志消息。在本教程中&#xff0c;我们将为其添加一项功能 &#xff0c;这个功能是我们将只订阅消息的一个子集成为可能。 例如&#xff0c;我们可以只将关键的错误消息输…

《此生未完成》痛句摘抄(4)

System.out.print("今天开始继续读书摘录"); //不知道官方让不让我在博客里面记录 //如果不让的话我可能得转到别的上面记录 System.out.print("现在开始看《此生未完成》"); System.out.println("今天是第四天&#xff01;"); System.out.print…

【jzoj3734,Usaco2014Open银组】双导航(gpsdual)

前言 这是今天C组的题&#xff0c;闲得无聊做了一会&#xff0c;结果就对了233。这算是学了SPFA之后的第一次实战了。反正其他C组题我也不想做了。好了现在bi~~&#xff08;系统自动屏蔽&#xff09;也在做这道题。 还有这道题的名字叫 正题 题目 一个有向图&#xff0c;有…