POJ 2253 Frogger (求某两点之间所有路径中最大边的最小值)

题意:有两只青蛙,a在第一个石头,b在第二个石头,a要到b那里去,每种a到b的路径中都有最大边,求所有这些最大边的最小值。
思路:将所有边长存起来,排好序后,二分枚举答案。

  时间复杂度比较高,344ms。

#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#include <math.h>using namespace std;
const int maxn=210;
const int INF=0x3f3f3f3f;
double w[maxn][maxn]; //存储边长
double wlen[30000];
int con[maxn][maxn]; //con[i][j]=1表示i、j连通,con[i][j]=0表示不连通
int idx;
int n;
struct Node{int x,y;
}node[maxn];
int main()
{int t=0,a,b;double length;int ans;while(scanf("%d",&n)!=EOF){if(n==0)break;t++;idx=0;memset(w,0,sizeof(w));printf("Scenario #%d\n",t);for(int i=0;i<n;i++){scanf("%d%d",&a,&b);node[i].x=a;node[i].y=b;}for(int i=0;i<n;i++){for(int j=i+1;j<n;j++){//pow传递的参数先要强制转换成double,否则提交编译错误length=pow(double(node[j].x-node[i].x),2)+pow(double(node[j].y-node[i].y),2);length=sqrt(length);w[i][j]=w[j][i]=length;wlen[idx++]=length;}}sort(wlen,wlen+idx);//二分枚举所有可能的值,floyd的时候考虑所有长度不大于该值的边int l=0,r=idx-1,mid;while(l<=r){mid=(l+r)>>1;for(int i=0;i<n;i++){for(int j=i+1;j<n;j++){//初始化,con[i][j]=1表示边i、j长度不大于枚举值,=0表示大于枚举值if(w[i][j]>wlen[mid])con[i][j]=con[j][i]=0;elsecon[i][j]=con[j][i]=1;}}for(int k=0;k<n;k++){for(int i=0;i<n;i++){for(int j=0;j<n;j++){//只要有一对con[i][k]、con[k][j]连通,con[i][j]就连通con[i][j]|=con[i][k]&con[k][j];}}}if(con[0][1]){r=mid-1;ans=mid;}else{l=mid+1;}}printf("Frog Distance = %.3lf\n",wlen[ans]);puts("");}return 0;
}

 

这里附上别人的代码:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
using namespace std;
double dist[202][202]; //dist[i][j]表示i到j的路径中边的最大值的最小值
int n;
struct Node {int x;int y;
} e[202];
void Floyd() {for(int k=0; k<n; k++) {for(int i=0; i<n; i++) {for(int j=0; j<n; j++) {if(max(dist[i][k],dist[k][j])<dist[i][j])dist[i][j]=max(dist[i][k],dist[k][j]);}}}}
int main() {int t=1;while(~scanf("%d",&n)) {if(n==0)break;for(int i=0; i<n; i++) {scanf("%d%d",&e[i].x,&e[i].y);}for(int i=0; i<n; i++) {for(int j=0; j<n; j++) {dist[i][j]=sqrt(pow((double)(e[i].x-e[j].x),2)+pow((double)(e[i].y-e[j].y),2));}}Floyd();printf("Scenario #%d\n",t++);printf("Frog Distance = %.3f\n\n",dist[0][1]);}
}

 

转载于:https://www.cnblogs.com/chenxiwenruo/p/3374271.html

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

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

相关文章

基于matlab的频率响应分析,基于MATLAB/GUI的二阶低通电路频率响应分析与仿真

第 34 卷 第 5 期 2011 年 10 月 电 子 器 件 Chinese Journal of Electron Devices Vol&#xff0e; 34 No&#xff0e; 5 Oct&#xff0e; 2011 项目来源: 基本电路的分析与综合实时演示系统( ndkf0908) 收稿日期:2011&#xff0d;04&#xff0d;19 修改日期:2011&#xff0d…

详解.NET IL代码(一)

本文主要介绍IL代码&#xff0c;内容大部分来自网上&#xff0c;进行整理合并的。 一、IL简介 为什么要了解IL代码&#xff1f; 如果想学好.NET&#xff0c;IL是必须的基础&#xff0c;IL代码是.NET运行的基础&#xff0c;当我们对运行结果有异议的时候&#xff0c;可以通过IL代…

CentOS yum安装mcrypt详细图解教程[linux]

在Linux的发行版CentOS 6.3 系统下&#xff0c;LAMP(LinuxApacheMysqlphp)环境搭建好后发现PHPMyadmin提示 “无法载入mcrypt模块” 的错误感觉很不爽&#xff0c;就尝试着使用yum安装提示找不到模块。如下为执行过程&#xff1a; [rootptr228 ~]# yum install php-mcrypt Sett…

matlab计算大米个数,如何求数组元素的个数 matlab

2016-11-21 回答比如说你的数组是a&#xff0c;那么元素个数可以这样求解&#xff1a;[m,n]size(a);numm*n例如&#xff1b;a 1 1 0 1 1 0 0 1 1 1 0 11 1 0 1 0 0 1 1 1 1 0 01 1 1 1 1 0 1 0 1 0 0 10 0 1 1 0 1 0 0 0 1 1 10 0 0 1 1 1 0 1 1 0 0 00 1 0 1 0 1 0 1 1 1 1 01…

软引用、弱引用、虚引用

阅读&#xff1a;http://sish#去掉我#uok.com/forum/posts/list/342.html 我很好奇为什么不能引用某网站的文字...... 对强弱等引用早有耳闻&#xff0c;却一直发现似乎无用武之地&#xff0c;今早看了 http://android-developers.blogspot.com/2010/07/multithreading-for-per…

matlab dll没有头文件,matlab调用dll没有头文件怎么办

2018-12-08 回答基于dll形式vc调用matlab函数方法如果在一matlab中或vc中写好了函数的话&#xff0c;想在对方的环境中使用&#xff0c;直接将对方语言的函数编译成dll是一个很方便的方法&#xff0c;不需要重写了。今天把基于dll形式vc调用matlab函数的主要过程写下&#xff0…

关于安装Ubuntu后触摸板无法使用的解决方案

安装了Ubuntu后发现触摸板无法使用&#xff0c;以为是修改了安装文件导致&#xff08;之前拿安装源文件做了小实验&#xff09;&#xff0c;于是重装&#xff0c;之后触摸板仍无法使用&#xff0c;在一个长满小广告的页面上找到了解决方案。 以下是原文章内容&#xff1a; 最近…

matlab实现频域率滤波,基于Matlab的图像的频域滤波实现及研究.doc

摘要&#xff1a;图像的频域滤波是图像增强的一种方法。图像增强是图像处理的方法之一&#xff0c;有频率域法和空间域法。频率域法把图像看成一种二维信号&#xff0c;对其进行二维傅里叶变换的信号增强&#xff0c;采用低通滤波法可以去掉图像的噪声&#xff1b;采用高通滤波…

python屏幕的交互(读取输出信息)input,raw_input的区别

>>> input("your name?") your name?sam Traceback (most recent call last): File "<pyshell#0>", line 1, in <module> input("your name?") File "<string>", line 1, in <module> Na…

php str pa,php截取字符串方法有哪些

php截取字符串方法有&#xff1a;1、使用substr函数截取字符串&#xff1b;2、使用mb_substr函数截取字符串&#xff1b;3、使用自定义的“function mysubstr($str, $start, $len){}”方法截取字符串等等。本文操作环境&#xff1a;windows7系统、PHP7.1版&#xff0c;DELL G3电…

matlab里box office,免费试用Econometrics Toolbox

请选择其一AlabamaAlaska美属萨摩亚APO/FPO AAAPO/FPO AEAPO/FPO APArizonaArkansasCaliforniaCaroline IslandsColoradoConnecticutDelawareDistrict of ColumbiaFlorida格鲁吉亚关岛HawaiiIdahoIllinoisIndianaIowaKansasKentuckyLouisianaMaineMariana Islands马绍尔群岛Mar…

[算法 笔记]2014年去哪儿网 开发笔试(续)第一题BUG修正

上一篇的blog地址为&#xff1a;http://www.cnblogs.com/life91/p/3313868.html 这几天又参加了一个家公司的笔试题&#xff0c;在最后的编程题中竟然出现了去哪儿网开发的第一题&#xff0c;也就是简化路径值。但是这次做题后&#xff0c;我发现我上次写的那个简化源码有很多问…

java封装264成flv,将H.264封装为FLV格式-Go语言中文社区

本文将介绍如何将H.264封装成flv格式。在看本文之间&#xff0c;建议先看一看下面两篇文章&#xff1a;首先说一说构建一个FLV文件需要什么&#xff1f;FLV Header FLv script tag FLV Video tag FLV Audio tag由于这里只是封装H.264&#xff0c;所以不包括Audio tag。下面将…

Activity 模版样式简介

1&#xff1a;对话框样式。 <activity android:theme"android:style/Theme.Dialog"> 2&#xff1a;透明样式。 <activity android:theme"android:style/Theme.Translucent"> 3&#xff1a;Light 样式,标题栏是细长型的&#xff0c;在4.0版本默…

java连接ldap验证,验证用户使用LDAP登录

我无法使用LDAP成功验证ASP.NET Web应用程序的用户 . 我已经在我们自己的网络上针对Active Directory这样做了&#xff0c;但这是针对我们网络之外的服务器&#xff0c;即OID(Oracle Internet Directory) .通常&#xff0c;我使用以下代码没有问题 .Dim myDirectoryEntry As Ne…

[转]iis7.5+win2008 出现 HTTP Error 503. The service is unavailable.

解决&#xff1a; 应用程序池启动32位应用程序 设置托管管道为集成 &#xff08;仍然有问题&#xff09; 试试以下方法&#xff1a; http://phpwind.me/1222.html 楼主 发表于: 2011-11-26 图片:123.png 访问网站之前 应用程序池是开启的 访问后 网页报503 service unavailabl…

mysql数据库的存储过程不用学吗,MySql数据库之存储过程学习_MySQL

之前在工作中总是听别人提到存储过程&#xff0c;觉得是个很高深的东西&#xff0c;利用工作之余&#xff0c;看了下相关的知识&#xff0c;现将学习知识总结如下&#xff0c;希望可以为刚学习的人提供些许帮助。开发环境&#xff1a;Navicat For Mysql。MySQL存储过程1.1、CRE…

// D:\SaveLog\_SaveLog.dpr立即备份晓亮的电脑操作记录热键(快捷键) F11由于原来的 AutoIt 杀毒软件总是误报没办法只好麻烦一点用 Delphi XE4 做了...

// D:\SaveLog\_SaveLog.dpr立即备份晓亮的电脑操作记录 热键(快捷键) F11由于原来的 AutoIt 杀毒软件总是误报没办法只好麻烦一点用 Delphi 各种版本 做了 (我主要用的版本是Delphi2007(Delphi11)) (从Delphi6到Embarcadero.Delphi.XE5.Lite) // D:\SaveLog\_SaveLog.dpr立即备…

python list sort by,python中List的sort方法指南

简单记一下python中List的sort方法(或者sorted内建函数)的用法。List的元素可以是各种东西&#xff0c;字符串&#xff0c;字典&#xff0c;自己定义的类等。sorted函数用法如下&#xff1a;sorted(data, cmpNone, keyNone, reverseFalse)其中&#xff0c;data是待排序数据&…

开站资源

1. 存储 七牛云存储 http://www.qiniu.com/ 2. 网站模板 https://drupal.org/ 参考&#xff1a;http://www.w3cplus.com转载于:https://www.cnblogs.com/javawer/p/3407065.html