连接的管道

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)

Total Submission(s): 1323    Accepted Submission(s): 519

Problem Description
老 Jack 有一片农田。以往几年都是靠天吃饭的。

可是今年老天格外的不开眼。大旱。所以老 Jack 决定用管道将他的全部相邻的农田全部都串联起来。这样他就能够从远处引水过来进行灌溉了。

当老 Jack 买全然部铺设在每块农田内部的管道的时候,老 Jack 遇到了新的难题。由于每一块农田的地势高度都不同,所以要想将两块农田的管道链接,老 Jack 就须要额外再购进跟这两块农田高度差相等长度的管道。



如今给出老 Jack农田的数据,你须要告诉老 Jack 在保证所有农田所有可连通灌溉的情况下,最少还须要再购进多长的管道。另外。每块农田都是方形等大的,一块农田仅仅能跟它上下左右四块相邻的农田相连通。

 
Input
第一行输入一个数字T(T≤10),代表输入的例子组数



输入包括若干组測试数据,处理到文件结束。

每组測试数据占若干行,第一行两个正整数 N,M(1≤N,M≤1000),代表老
Jack 有N行*M列个农田。接下来 N 行。每行 M 个数字,代表每块农田的高度,农田的高度不会超过100。数字之间用空格分隔。

 
Output
对于每组測试数据输出两行:



第一行输出:"Case #i:"。i代表第i组測试数据。



第二行输出 1 个正整数。代表老 Jack 额外最少购进管道的长度。

 
Sample Input
2
4 3
9 12 4
7 8 56
32 32 43
21 12 12
2 3
34 56 56
12 23 4
 
Sample Output
Case #1:
82
Case #2:
74
 
Source

思路:

最小生成树,在图要求所有联通的情况下求最短的权值,用最短路。想用搜索之类的要考虑数据大小。

代码:

#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<algorithm>
using namespace std; struct node
{
int x,y,len;
bool operator < (const node &a) const
{
return len < a.len;
}
};
const int N=1100;
int x[N][N],m,n,k;
int father[N*N];
node ve[N*N*4]; int Find(int x)
{
return x==father[x]? x:father[x]=Find(father[x]);
} int Union(int x,int y)
{
int a=Find(x),b=Find(y);
if(a!=b)
{
father[a]=b;
return 1;
}
return 0;
} int kruskal()
{
node s;
int sum=0;
for(int i=0;i<k;i++)
{
if(Union(ve[i].x,ve[i].y))
sum+=ve[i].len;
}
return sum;
} int main()
{
int na,ca=1;
scanf("%d",&na);
while(na--)
{
k=0;
scanf("%d%d",&m,&n);
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
{
node q;
father[i*n+j]=i*n+j;
scanf("%d",&x[i][j]); if(j>0)
{
q.x=i*n+j,q.y=i*n+j-1;
q.len=abs(x[i][j]-x[i][j-1]);
ve[k++]=q;
}
if(i>0)
{
q.x=i*n+j,q.y=i*n+j-n;
q.len=abs(x[i][j]-x[i-1][j]);
ve[k++]=q;
}
}
sort(ve,ve+k);
printf("Case #%d:\n",ca++);
int xx=kruskal();
printf("%d\n",xx);
}
return 0;
}

hdu 5253 连接的管道(kruskal)(2015年百度之星程序设计大赛 - 初赛(2))的更多相关文章

  1. HDU 6114 Chess 【组合数】(2017"百度之星"程序设计大赛 - 初赛(B))

    Chess Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  2. HDU 6122 今夕何夕 【数学公式】 (2017"百度之星"程序设计大赛 - 初赛(A))

    今夕何夕 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  3. HDU 5251 矩形面积(二维凸包旋转卡壳最小矩形覆盖问题) --2015年百度之星程序设计大赛 - 初赛(1)

    题目链接   题意:给出n个矩形,求能覆盖所有矩形的最小的矩形的面积. 题解:对所有点求凸包,然后旋转卡壳,对没一条边求该边的最左最右和最上的三个点. 利用叉积面积求高,利用点积的性质求最左右点和长度 ...

  4. HDU 6108.小C的倍数问题 (2017"百度之星"程序设计大赛 - 初赛(A)1001)

    补完题?不存在的. 这么久了,还是一条咸鱼,看一堆乱七八糟的东西,写一堆没用的水题,一点进步都没有,还是那么菜,菜的掉渣. 这个百毒之星初赛A还会写两道最简单的水题,初赛B一点也不会,菜的难过... ...

  5. HDU 6118 度度熊的交易计划 【最小费用最大流】 (2017"百度之星"程序设计大赛 - 初赛(B))

    度度熊的交易计划 Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  6. HDU 6119 小小粉丝度度熊 【预处理+尺取法】(2017"百度之星"程序设计大赛 - 初赛(B))

    小小粉丝度度熊 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  7. HDU 6109 数据分割 【并查集+set】 (2017"百度之星"程序设计大赛 - 初赛(A))

    数据分割 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  8. HDU 6108 小C的倍数问题 【数学】 (2017"百度之星"程序设计大赛 - 初赛(A))

    小C的倍数问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  9. HDU 6113 度度熊的01世界 【DFS】(2017"百度之星"程序设计大赛 - 初赛(A))

    度度熊的01世界 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Su ...

随机推荐

  1. Go语言 之产生随机数

    package main import ( "fmt" "math/rand" "strconv" "time" ) f ...

  2. PHP 中 echo 和 print 的区别

    一般来说,PHP中动态输出HTML内容,是通过print 和 echo 语句来实现的,在实际使用中, print 和 echo 两者的功能几乎是完全一样.可以这么说,凡是有一个可以使用的地方,另一个也 ...

  3. 哈尔滨工程大学ACM预热赛 补题

    链接:https://ac.nowcoder.com/acm/contest/554/A来源:牛客网 小虎刚刚上了幼儿园,老师让他做一个家庭作业:首先画3个格子,第二行有2个格子,第三行有1个格子. ...

  4. 09CSS高级定位

    CSS高级定位 定位方式——position position:static|absolute|relative static表示为静态定位,是默认设置.  absolute表示绝对定位,与下位置属 ...

  5. 02CSS基本语法

    CSS基本语法 id选择符 在HTML文档中,需要唯一标识一个元素时,就会赋予它一个id标识,以便在对整个文档进行处理时能够很快地找到这个元素. 而id选择符就是用来对这个单一元素定义单独的样式.#号 ...

  6. No-1.第一个 Python 程序

    1. 第一个 HelloWorld 程序 1.1 Python 源程序的基本概念 Python 源程序就是一个特殊格式的文本文件,可以使用任意文本编辑软件做 Python 的开发 Python 程序的 ...

  7. Spring Data Redis入门示例:Hash操作(七)

    将对象存为Redis中的hash类型,可以有两种方式,将每个对象实例作为一个hash进行存储,则实例的每个属性作为hash的field:同种类型的对象实例存储为一个hash,每个实例分配一个field ...

  8. joda-time时间操作组件

    今天看到了学习到了一个不错的操作时间的jar包,很方便的,以后操作时间运算就可以直接使用jar包中的方法了,再也不用自己写操作时间的方法了.懒的不行不行的 <!-- 时间操作组件 --> ...

  9. iframe天气预报

    <iframe style="float: right;" width="420" scrolling="no" height=&qu ...

  10. Ubuntu终端常用快捷键汇总

    Ubuntu终端常用的快捷键 - 转自- 博客园  http://www.cnblogs.com/nucdy/p/5251659.html   Ubuntu中的许多操作在终端(Terminal)中十分 ...