HDOJ 1875 HDU 1875 畅通工程再续 ACM 1875 IN HDU

MiYu原创, 转帖请注明 : 转载自 ______________白白の屋

题目地址:
         http://acm.hdu.edu.cn/showproblem.php?pid=1875
题目描述:
畅通工程再续

Time Limit: 
2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 
3822    Accepted Submission(s): 1076


Problem Description
相信大家都听说一个“百岛湖”的地方吧,百岛湖的居民生活在不同的小岛中,当他们想去其他的小岛时都要通过划小船来实现。现在政府决定大力发展百岛湖,发展首先要解决的问题当然是交通问题,政府决定实现百岛湖的全畅通!经过考察小组RPRush对百岛湖的情况充分了解后,决定在符合条件的小岛间建上桥,所谓符合条件,就是2个小岛之间的距离不能小于10米,也不能大于1000米。当然,为了节省资金,只要求实现任意2个小岛之间有路通即可。其中桥的价格为 100元
/米。
 

Input
输入包括多组数据。输入首先包括一个整数T(T 
<= 200),代表有T组数据。
每组数据首先是一个整数C(C 
<= 100),代表小岛的个数,接下来是C组坐标,代表每个小岛的坐标,这些坐标都是 0 <= x, y <= 1000的整数。
 

Output
每组输入数据输出一行,代表建桥的最小花费,结果保留一位小数。如果无法实现工程以达到全部畅通,输出”oh
!”.
 

Sample Input
2
2
10 10
20 20
3
1 1
2 2
1000 1000
 

Sample Output
1414.2
oh
!

题目分析:
因为边没有直接给出, 而是给的坐标点, 所以需要先计算 每一个点到其他任意一点的距离, 并且记录下来.  如下 :
      for ( int i = 1; i <= N; ++ i )
           {
                 for ( int j = 1; j < i; ++ j )
                 {
                       edge[n].v1 = i;
                       edge[n].v2 = j;
                       edge[n].len = sqrt ( 0.0 + POW (LD[i].x - LD[j].x) + POW ( LD[i].y - LD[j].y ) ); 
                       n ++;
                 }
           }
注意红色部分!!  这样做很安全, 不加的话, G++可以通过,但在C++上会出现编译问题, 哥悲剧了2次 CE   T .T.

将边记录好以后, 就是正宗的 最小生成树问题了.........直接KRUSKAL了. 这个我比较熟习, 呵呵.

代码如下:
MiYu原创, 转帖请注明 : 转载自 ______________白白の屋


#include 
<iostream>
#include 
<algorithm>
#include 
<cmath>
#define POW(x) ( (x) * (x) )
using namespace std;
typedef 
struct {
     
int parent;
     
int height;   
}Tset;  
typedef 
struct treeUFS{
       
public:
              treeUFS(
int n = 0):N(n+1) { set = new Tset[N];
                                          visited 
= new bool[N]; 
                                          
for ( int i = 0; i != N; ++ i) 
                                          
set[i].parent = i,set[i].height = 1,visited[i] = false
                                        }
              
~treeUFS(){ delete [] set; };
              
int find ( int x ){  int r = x;  while ( r != set[r].parent ) r = set[r].parent;
                                   
return r;
                                }
              
void setVisit ( int x, int y ) { visited[x] = visited[y] = true; } 
              
bool getVisit ( int x ) { return visited[x]; }
              
void Merge( int x,int y ){  x = find ( x );  y = find ( y );  
                                           
if ( x == y ) return;
                                           
if ( set[x].height == set[y].height ){
                                                
set[y].parent = x;
                                                
set[x].height ++;
                                           }
                                           
else if ( set[x].height < set[y].height ) {
                                                     
set[x].parent = y;       
                                                   }
                                           
else{   set[y].parent = x;
                                               }
                                        }
              
int getTreeCount (){ int nCount = 0for ( int i = 1; i < N; ++ i ){
                                                         
if ( find (i) == i ){
                                                              nCount 
++
                                                         }
                                                   }
                                   
return nCount;
                                 }
       
private:
              Tset 
*set;
              
bool *visited;
              
int N;         
}treeUFS; 
struct island{
       
int x,y;
}LD[
105];
typedef 
struct edge{
       
int v1,v2;
       
double len;
}EDGE;
EDGE edge[
5050];
bool cmp ( EDGE A, EDGE B )
{
     
return A.len < B.len; 
}
int main ()
{
    
int T;
    scanf ( 
"%d",&T );
    
while ( T -- )
    {
           
int N;
           scanf ( 
"%d",&N );
           treeUFS UFS ( N );
           
for ( int i = 1; i <= N; ++ i )
           {
                 
int x,y;
                 scanf ( 
"%d%d",&LD[i].x,&LD[i].y );
           } 
           
int n = 1;
           
for ( int i = 1; i <= N; ++ i )
           {
                 
for ( int j = 1; j < i; ++ j )
                 {
                       edge[n].v1 
= i;
                       edge[n].v2 
= j;
                       edge[n].len 
= sqrt ( 0.0 + POW (LD[i].x - LD[j].x) + POW ( LD[i].y - LD[j].y ) ); 
                       n 
++;
                 }
           }
           
double sum = 0.0;
           n 
= N * ( N - 1 ) / 2;
           sort ( edge 
+ 1, edge + n + 1 , cmp );
           
for ( int i = 1; i <= n; ++ i )
           {
                 
if ( ( ( !UFS.getVisit(edge[i].v1) || !UFS.getVisit(edge[i].v2) ) || UFS.find(edge[i].v1) != UFS.find(edge[i].v2) ) && edge[i].len >=10 && edge[i].len <= 1000 ) 
                 {
                        UFS.setVisit ( edge[i].v1, edge[i].v2 );
                        UFS.Merge ( edge[i].v1, edge[i].v2 );
                        sum 
+= edge[i].len; 
                 }
           }
           
int tCount = UFS.getTreeCount();
           
if ( tCount != 1 )
           {
                 puts ( 
"oh!" );
                 
continue
           }
           printf ( 
"%.1lf\n",sum * 100 );
    }
    
return 0
}

转载于:https://www.cnblogs.com/MiYu/archive/2010/08/18/1802678.html

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

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

相关文章

CSharp设计模式读书笔记(10):装饰模式(学习难度:★★★☆☆,使用频率:★★★☆☆)...

装饰模式(Decorator Pattern)&#xff1a; 动态地给一个对象增加一些额外的职责&#xff0c;就增加对象功能来说&#xff0c;装饰模式比生成子类实现更为灵活。 模式角色与结构&#xff1a; 示例代码&#xff1a; using System; using System.Collections.Generic; using Syste…

ShardingCore 如何呈现“完美”分表

这篇文章是我针对efcore的分表的简单介绍,如果您有以下需求那么可以自己选择是否使用本框架,本框架将一直持续更新下去&#xff0c;并且免费开源为.net生态做贡献,如果您觉得不错那么请帮忙点个star谢谢&#xff0c;框架地址[sharding-core](https://github.com/xuejmnet/shard…

使用javascript oop开发滑动(slide) 菜单控件

这里使用原生的javascript&#xff0c;用面向对象的方式创建一个容易维护使用方便的滑动菜单&#xff0c;调用方式如下&#xff1a;var$sliding document.getElementById("silding");vars1 newSliding();s1.commands $sliding.getElementsByTagName("dt");…

这段代码什么意思啊?

这段代码什么意思啊? Delphi / Windows SDK/APIhttp://www.delphi2007.net/DelphiDB/html/delphi_20061217214802252.htmlprocedure TForm3.RadioButton3Click(Sender: TObject); begin ADOTable1.refresh; with ADOTable1 do try disablecontrols; filte…

他毕业于北师大,编写了我国首套数学教材,陈景润华罗庚都崇拜他

全世界只有3.14 % 的人关注了爆炸吧知识要说起我国著名的数学家&#xff0c;很多人会想到陈景润、华罗庚等人&#xff0c;这些大数学家为我国数学研究做出了卓越贡献&#xff0c;也深深影响了很多人。那么&#xff0c;像陈景润、华罗庚这些大数学家&#xff0c;他们学习数学有受…

用多媒体库 Bass.dll 播放 mp3 [8] - 实时显示左右声道的峰值

为什么80%的码农都做不了架构师&#xff1f;>>> 本例效果图: 代码文件: unit Unit1;interfaceusesWindows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,Dialogs, StdCtrls, ExtCtrls, ComCtrls;typeTForm1 class(TForm)OpenDialog1: TOpe…

最近看了两本低代码的书

月初写了一篇《你真的了解低代码平台吗&#xff1f;》&#xff0c;介绍了下我对低代码产品的一些认识&#xff0c;随后有朋友送了我两本华章出版的关于低代码的书&#xff1a;明道云的《零代码实战》和微软的《实战低代码》&#xff0c;目前市面上也就这两本关于低代码的书。因…

如何逼疯一名数学系学生?

全世界只有3.14 % 的人关注了爆炸吧知识今天在知乎竟看到这样一个问题但看在关注人数如此之多超模君就放下成见稍微透露一下我们的“底线”到底要怎样做才能激怒数学系学生数学沾边法顾名思义只要和数学沾边就可以开怼在菜市场算菜钱时在提问后的0.5秒迅速补上致命一刀经过彩票…

java 图片压缩 base64_图片改变像素,宽高,Base64编码处理

1.改变图片像素private void setAlpha(String os) {/*** 增加测试项* 读取图片&#xff0c;绘制成半透明,修改像素*/try {ImageIcon imageIcon new ImageIcon(os);BufferedImage bufferedImage new BufferedImage(imageIcon.getIconWidth(),imageIcon.getIconHeight(), Buffe…

WinAPI: 钩子回调函数之 MouseProc

为什么80%的码农都做不了架构师&#xff1f;>>> MouseProc(nCode: Integer; {}wParam: WPARAM; {}lParam: LPARAM {} ): LRESULT; {}//待续...转载于:https://my.oschina.net/hermer/blog/320962

shell对于字符串的操作

shell对于字符串的操作:以下为代码内容&#xff1a;得到长度 代码:%x"abcd" # 方法一 %expr length $x 4 # 方法二 %echo ${#x} 4 # 方法三 %expr "$x" : ".*" 4 # expr 的帮助 # STRING : REGEXP anchored pattern match of REGEXP in STRING…

方法参数修饰符in,out,ref

in&#xff0c;out&#xff0c;ref都可能作为方法参数据修饰符&#xff0c;从字面意思可就可以理解这三个关键字的含义&#xff0c;那用法是什么样子的呢&#xff0c;通过demo来看一下。定义一个引用类型Orderpublic class Order {public string OrderNo { get; set; }public o…

hdoj 1272

题目链接http://acm.hdu.edu.cn/showproblem.php?pid1272 并查集 1 #include <iostream>2 #include <algorithm>3 4 usingnamespacestd;5 6 intf[100001];7 booldis[100001];8 9 intFind(intx)10 {11 while( x !f[x] ){12 x f[x];13 }14 15 returnx;16 }17 18 int…

配置Tomcat的日志系统

成功配置tomcat的log4j日志系统&#xff0c;格式&#xff1a;HTML&#xff0b;每天以yyyy-mm-dd.log命名的日志文件一、引言&#xff1a;实习单位让用log4j配置webapp的日志系统&#xff0c;要求产生的日志文件是html格式&#xff0c;而且是每天以yyyy-mm-dd日期格式命名的日志…

python训练词库_在Python中训练NGramModel

首先,正如您对问题的评论中所指出的,如果培训/运行速度对您来说是一个问题,KenLM可能是更好的选择.此时nltk.model主要用于教育/原型设计,但它并不快.如果您仍然决定坚持使用NLTK,请继续阅读.我碰巧是模型分支中新的NgramModel代码的作者,我会尝试清楚地说明你可以测试代码并让…

内推!字节、阿里、网易火热招聘中,内推优筛简历,快人一步拿offer,真香!(送内推码)...

全世界只有3.14 % 的人关注了爆炸吧知识“金三银四”可谓招聘的黄金期。一方面&#xff0c;校园春招正如火如荼的进行中&#xff0c;另一方面&#xff0c;各大企业也纷纷启动了暑假实习招聘。对于2020届的同学来说&#xff0c;务必要利用好“应届生”这个身份&#xff0c;把握住…

如何将10进制转成16进制,又如何将16进制数转成10进制,C#和VB代码?

方法1&#xff1a; int d10; d.ToString("x") //或把x改为&#xff38;&#xff0c;&#xff0c;&#xff0c;就变成了&#xff11;&#xff16;位的字符串了&#xff0e; int xConvert.ToInt32(d.ToString("x"),16);&#xff0f;&a…

C#怎么测试静态方法?我给出了2种方案

问题假设有一个方法需要判断当前小时范围&#xff0c;代码如下&#xff1a;public class Class1 {public bool SomeMethod(){var hour DateTime.Now.Hour;if (hour > 9 && hour < 12){return true;}return false;} }但是&#xff0c;在做单元测试时&#xff0c;…

关于Tomcat5.5中EL表达式无效的解决办法

问题&#xff1a; 在Tomcat5.5中&#xff0c;JSP页中使用EL表达式输出信息&#xff0c;例如&#xff1a; <% page language”java” import”java.util.*” pageEncoding”UTF-8″%><html><head>EL表达式</head><body>${header["User-Agent…

c语言全局变量和局部变量问题汇总

1、局部变量是否能和全局变量重名&#xff1f; 答&#xff1a;能&#xff0c;局部会屏蔽全局。要用全局变量&#xff0c;须要使用"::" 局部变量能够与全局变量同名&#xff0c;在函数内引用这个变量时&#xff0c;会用到同名的局部变量&#xff0c;而不会用到全局变…