Highways

Time Limit:1000MS     Memory Limit:10000KB     64bit IO Format:%I64d & %I64u

Submit Status

Description

The island nation of Flatopia is perfectly flat. Unfortunately, Flatopia has a very poor system of public highways. The Flatopian government is aware of this problem and has already constructed a number of highways connecting some of the most important towns. However, there are still some towns that you can't reach via a highway. It is necessary to build more highways so that it will be possible to drive between any pair of towns without leaving the highway system.

Flatopian towns are numbered from 1 to N and town i has a position given by the Cartesian coordinates (xi, yi). Each highway connects exaclty two towns. All highways (both the original ones and the ones that are to be built) follow straight lines, and thus their length is equal to Cartesian distance between towns. All highways can be used in both directions. Highways can freely cross each other, but a driver can only switch between highways at a town that is located at the end of both highways.

The Flatopian government wants to minimize the cost of building new highways. However, they want to guarantee that every town is highway-reachable from every other town. Since Flatopia is so flat, the cost of a highway is always proportional to its length. Thus, the least expensive highway system will be the one that minimizes the total highways length.

Input

The input consists of two parts. The first part describes all towns in the country, and the second part describes all of the highways that have already been built.

The first line of the input file contains a single integer N (1 <= N <= 750), representing the number of towns. The next N lines each contain two integers, xi and yi separated by a space. These values give the coordinates of i th town (for i from 1 to N). Coordinates will have an absolute value no greater than 10000. Every town has a unique location.

The next line contains a single integer M (0 <= M <= 1000), representing the number of existing highways. The next M lines each contain a pair of integers separated by a space. These two integers give a pair of town numbers which are already connected by a highway. Each pair of towns is connected by at most one highway.

Output

Write to the output a single line for each new highway that should be built in order to connect all towns with minimal possible total length of new highways. Each highway should be presented by printing town numbers that this highway connects, separated by a space.

If no new highways need to be built (all towns are already connected), then the output file should be created but it should be empty.

Sample Input

9
1 5
0 0
3 2
4 5
5 1
0 4
5 2
1 2
5 3
3
1 3
9 7
1 2

Sample Output

1 6
3 7
4 9
5 7
8 3   这道题就是给出了n个村的坐标,然后给出了m条路,表示已经修好的路,不过要求的不是求最小权值,而是问,修建哪些路最优,输出需要修的路。
  既然这道题要求的是输出需要修建的路,只需要在把一个点从v拿出加到u里的同时,记录下这条边就OK了,所以,可以再维护一个数组,pre[MAXN],
因为cost[i][j]表示i和j之间的权值为cost[i][j],所以连接j的时候更新pre[j],即:
pre[i]表示j这个点的前导节点,在扫描u,v之间的最小边的同时更新pre[i].
  这道题不是直接给出了点,而是给出了点的坐标,其实只需要定义一个Point,用来存储点的坐标,point[i]的坐标为point[i].x和point[i].y
  另外,输出的顺序可以不一样,我开始就是因为顺序不一样不敢交。

#include<cstdio>
#include<cstring>
#include<cmath>
const double INF=999999999.9;//注意这里是double,我开始逗比写成了int

const int MAXN=755;
struct Point
{
  double x,y;
}point[MAXN];
double cost[MAXN][MAXN];
bool vis[MAXN];
double lowc[MAXN];
int pre[MAXN];
int tot;//记得初始化
double get_dis(int i,int j)
{
  return sqrt((point[i].x-point[j].x)*(point[i].x-point[j].x)+(point[i].y-point[j].y)*(point[i].y-point[j].y));

  //这里其实可以不开方
}
int prim(int n)
{
  memset(vis,false,sizeof(vis));
  memset(pre,0,sizeof(pre));//初始化
  vis[1]=true;
  double ans=0.0;//double double double 
  for(int i=2;i<=n;i++)
  {
    lowc[i]=cost[1][i];
    pre[i]=1;//点i的前导节点是1
  }
  for(int i=2;i<=n;i++)
  {
    double minc=INF;
    int p=-1;
    for(int j=1;j<=n;j++)
      if(!vis[j]&&lowc[j]<minc)
      {
        minc=lowc[j];
        p=j;
      }
    if(minc==INF)
      return -1;
    ans+=minc;
    vis[p]=true;
    if(cost[p][pre[p]]!=0||cost[pre[p]][p]!=0)
    {
      printf("%d %d\n",pre[p],p);//注意空格
    }
    for(int j=1;j<=n;j++)
      if(!vis[j]&&cost[p][j]<lowc[j])
      {
        lowc[j]=cost[p][j];
        pre[j]=p;//更新
      }
  }
  return ans;
}
int main()
{
  int n;
  while(scanf("%d",&n)!=EOF)
  {
    for(int i=1;i<=n;i++)
    {
      scanf("%lf%lf",&point[i].x,&point[i].y);//double型输入用lf,因为这个也逗比了很久
    }
    for(int i=1;i<=n;i++)
    {
      lowc[i]=INF;//初始化

      for(int j=1;j<=n;j++)
      {
        cost[i][j]=get_dis(i,j);
      }
    }
    int m;
    int u,v;
    scanf("%d",&m);
    for(int i=1;i<=m;i++)
    {
      scanf("%d%d",&u,&v);
      cost[u][v]=cost[v][u]=0;
    }
    double ans=prim(n);
    if(ans==0.0)
    printf("\n");
  }
  return 0;
}


poj_2485_mst的更多相关文章

随机推荐

  1. 课堂所讲整理:HTML--6运算符、类型转换

    1.类型转换: 分为自动转换和强制转换,一般用强制转换. 其他类型转换为整数:parseint(): 其他类型转换为小数:parsefloat(): 判断是否是一个合法的数字类型:isNaN(): 是 ...

  2. 错误:无法访问android.app.Activity 找不到android.app.Activity的类文件

    视频里面在工程ndk22/bin/classes中 运行javah  com.cn.ndk22.Ndk22.Activity ,出现了.h文件 但是我在bin/classes目录中运行javah 时出 ...

  3. Linux驱动设计——字符设备驱动(一)

    Linux字符设别驱动结构 cdev结构体 struct cdev { struct kobject kobj; struct module *owner; const struct file_ope ...

  4. [POI 2008][BZOJ 1132]Tro

    这题我真是无能为力了 这题的做法还是挺简单的 枚举左下角的点做为原点,把其余点按极角排序    PS.是作为原点,如枚举到 k 时,对于所有 p[i] (包括p[k]) p[i]-=p[k] (此处为 ...

  5. 比较实用的JavaScript库

    如果你操作过cookie的接口,那么你一定会感觉这东西的规范真的是太复杂了,根本记不住啊,其实你是对的,因为cookie的接口设计的是有问题的,也就是说设计的太底层了,根本不友好,那么来试试这个js库 ...

  6. Articles Every Programmer Must Read

    http://javarevisited.blogspot.sg/2014/05/10-articles-every-programmer-must-read.html Being a Java pr ...

  7. 套接字I/O模型-重叠I/O

    重叠模型的基本设计原理是让应用程序使用重叠的数据结构,一次投递一个或多个WinsockI/O请求.针对那些提交的请求,在它们完成之后,应用程序可为它们提供服务.模型的总体设计以Windows重叠I/O ...

  8. DbContextConfiguration 属性

    属性 AutoDetectChangesEnabled 获取或设置一个值,该值指示是否通过 DbContext 和相关类的方法自动调用 DetectChanges 方法. 默认值为 true. Ens ...

  9. 运行setup.js文件

    C:\Windows\System32>wscript.exe setup.js

  10. 使自定义事件支持多绑定 js

    <script language="JavaScript" type="text/javascript"> <!-- //定义类class1 ...