连接格点题解
来源:互联网 发布:营销网络 代码 编辑:程序博客网 时间:2024/05/16 15:57
描述
Problem 2 : grid
连接格点
问题描述:
有一个M行N列的点阵,相邻两点可以相连。一条纵向的连线花费一个单位,一条横向的连线花费两个单位。某些点之间已经有连线了,试问至少还需要花费多少个单位才能使所有的点全部连通。
输入格式
第一行输入两个正整数m和n。
以下若干行每行四个正整数x1,y1,x2,y2,表示第x1行第y1列的点和第x2行第y2列的点已经有连线。输入保证|x1-x2|+|y1-y2|=1。
输出格式
输出使得连通所有点还需要的最小花费。
测试样例1
输入
输入样例
2 2
1 1 2 1
输出
输出样例
3
备注
时间限制:
各测试点1秒。
内存限制:
你的程序将被分配32MB的运行空间。
数据规模:
m,n
Tyvj上一道最小生成树的题,居然被我用模拟做出来了
#include<cstdio>
#include<algorithm>
#include<iostream>
using namespace std;
int n,m,xa,ya,xb,yb,tot,b[1001][1001];
bool a[1005];
int main()
{
freopen("grid.in","r",stdin);
freopen("grid.out","w",stdout);
scanf("%d%d",&m,&n);
tot=(n-1)*2+(m-1)*n;
while(cin>>xa>>ya>>xb>>yb)
{
b[xa][ya]++;
b[xb][yb]++;
if(xa-xb) --tot;
else
if(!a[min(ya,yb)])
{
a[min(ya,yb)]=true;
tot-=2;
}
else if(b[xa][ya]<2||b[xb][yb]<2) --tot;
}
printf("%d",tot);
return 0;
}
tot初始化为最大需要连的长度,以后每有一条有效边,就减去当前边权
b数组统计每个点的度数,如果小于2就连接有效
- 连接格点题解
- 连接格点
- Fzoj1616连接格点
- 24点游戏题解
- 连接格点 解题报告
- 【模拟试题】连接格点
- 连接点
- 连接点
- 连接点
- 方格取点问题--题解
- [Tarjan缩点] POJ1236题解
- hdu1498题解-再次白话最小点覆盖
- POJ 3714 Raid 最近对点题解
- 【BZOJ】【P1123】【POI2008】【BLO】【题解】【割点】
- [Tarjan缩点]BZOJ1051 YZOI2099题解
- 【BZOJ】【P1468】【Tree】【题解】【点分治】
- 【BZOJ】【P2599】【IOI2011】【Race】【题解】【点分治】
- vijos P1134 算24点 题解
- 菜鸟机器学习之路
- Squid 代理服务器安装配置和使用
- JavaScript 笔记本
- WOJ1055-The Hardest Problem Ever
- 解决项目启动时Tomcat 报io异常
- 连接格点题解
- 有关H5...新增的一些标签和全局属性.....(标签有语义化)兼容到IE9+,包括IE9;
- 1N4148的导通电压
- 实现MP4文件边下载边播放
- 计算机系统知识
- Error executing aapt: Cannot run program "/home/song/dev_tool/adt-bundle-linux-x86_64-20140702/sdk/b
- Umeng Share 友盟分享返回错误码相关:2001
- 个人项目优化小细节总结
- 用cforeach显示两层List