noip2002矩阵覆盖(搜索)
矩阵覆盖
题目描述
在平面上有 n 个点(n <= 50),每个点用一对整数坐标表示。例如:当 n=4 时,4个点的坐标分另为:p1(1,1),p2(2,2),p3(3,6),P4(0,7),见图一。

这些点可以用 k 个矩形(1<=k<=4)全部覆盖,矩形的边平行于坐标轴。当 k=2 时,可用如图二的两个矩形 sl,s2 覆盖,s1,s2 面积和为 4。问题是当 n 个点坐标和 k 给出后,怎样才能使得覆盖所有点的 k 个矩形的面积之和为最小呢。约定:覆盖一个点的矩形面积为 0;覆盖平行于坐标轴直线上点的矩形面积也为0。各个矩形必须完全分开(边线与顶点也都不能重合)。
输入输出格式
输入格式:
n k xl y1 x2 y2 ... ...
xn yn (0<=xi,yi<=500)
输出格式:
输出至屏幕。格式为:
一个整数,即满足条件的最小的矩形面积之和。
输入输出样例
4 2
1 1
2 2
3 6
0 7
/*
初始时,所有矩形的左下点坐标(+∞,+∞),右上角坐标(-∞,-∞)
然后按输入顺序,一个点一个点挨个搜
判断被搜的那个点是否被所有矩形覆盖了,如果有矩形没有覆盖这个点,
该矩形以最优解形式覆盖这个点(即这个点在矩形的边上),
每搜一个点后,就判断当前状态下,所有矩形是否没有覆盖,把不合法的废枝丢掉,提高效率
*/
#include <stdio.h>
#include <stdlib.h>
#define MAXN 100
#define INF 0x3f3f3f3f
int ans=INF,n,k;
struct point
{
int x;//该点的x坐标
int y;//该点的y坐标
}dots[MAXN];
struct square
{
struct point l; //左下角的点l
struct point r; //右上角的点r
}sqr[];
int checkit(int i,int j) //检查第i、j个矩形之间是否有冲突(即两个矩形有重叠区域)
{
if(sqr[i].l.x==INF||sqr[i].l.y==INF||sqr[i].r.x==-INF||sqr[i].r.y==-INF)
return ;
if(sqr[j].l.x==INF||sqr[j].l.y==INF||sqr[j].r.x==-INF||sqr[j].r.y==-INF)
return ;
if(sqr[i].l.x>sqr[j].r.x||sqr[i].l.y>sqr[j].r.y)
return ;
if(sqr[j].l.x>sqr[i].r.x||sqr[j].l.y>sqr[i].r.y)
return ;
return ;
}
int check() //检查当前所有已知矩形是否都合法。合法返回1
{
int i,j;
for(i=;i<k;i++)
{
for(j=i+;j<k;j++)
if(checkit(i,j))
return ;
}
return ;
}
int getsqr() //函数获取当前所有矩形覆盖面积之和
{
int i,ans=;
for(i=;i<k;i++)
{
if(sqr[i].l.x!=INF)
ans+=(sqr[i].r.x-sqr[i].l.x)*(sqr[i].r.y-sqr[i].l.y);
}
return ans;
}
void srch(int now) //寻找第now个点时矩形是否能覆盖
{
if(now==n) //搜索完成
{
ans=getsqr(); //获取当前所有矩形覆盖面积
return;
}
int i,j;
for(i=;i<k;i++) //从第0个矩形循环搜索到第k-1个矩形,判断矩形是否覆盖了点now
{
struct square tmp=sqr[i];
if(sqr[i].l.x>dots[now].x)
sqr[i].l.x=dots[now].x;
if(sqr[i].l.y>dots[now].y)
sqr[i].l.y=dots[now].y;
if(sqr[i].r.x<dots[now].x)
sqr[i].r.x=dots[now].x;
if(sqr[i].r.y<dots[now].y)
sqr[i].r.y=dots[now].y;
if(check()&&getsqr()<ans) //如果该步完成后,之前所有矩形都是合法的,且当前所有已求出的矩形面积比当前最优解小,则向深层(下一个点)搜索
srch(now+);
sqr[i]=tmp;
}
}
int main()
{
int i,j;
scanf("%d%d",&n,&k);
for(i=;i<n;i++)
scanf("%d%d",&dots[i].x,&dots[i].y);
for(i=;i<k;i++)
{
sqr[i].l.x=INF;
sqr[i].l.y=INF;
sqr[i].r.x=-INF;
sqr[i].r.y=-INF;
}
srch();
printf("%d",ans);
return ;
}
心若向阳,无谓悲伤
noip2002矩阵覆盖(搜索)的更多相关文章
- [LuoguP1034][Noip2002] 矩形覆盖
[LuoguP1034][Noip2002] 矩形覆盖(Link) 在平面上有\(N\)个点,\(N\)不超过五十, 要求将这\(N\)个点用\(K\)个矩形覆盖,\(k\)不超过\(4\),要求最小 ...
- 【BZOJ2003】[HNOI2010]矩阵(搜索)
[BZOJ2003][HNOI2010]矩阵(搜索) 题面 懒得粘了,不难找吧. 题解 看的学长写的题解,也懒得写了 大概是这样的. 不难发现只需要确定第一行和第一列就能确定答案,而确定第一行之后每确 ...
- 【校招面试 之 剑指offer】第10-3题 矩阵覆盖问题
题目:我们可以使用2✖️1的小矩形横着或者竖着去覆盖更大的矩形.请问用8个2✖️1的小矩形无重叠地覆盖一个2✖️8的大矩形,共有多少种方法? 分析:当放第一块时(假定从左边开始)可以横着放,也可以竖着 ...
- c++刷题(21/100)树的打印、矩阵覆盖和括号生成
题目一:把二叉树打印成多行 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行. 思路:一开始以为2维的vector可以直接访问,但是试了是不行,会报错,vector在有值之前不能直接访问 ...
- LeetCode第[79]题(Java):Word Search(矩阵单词搜索)
题目:矩阵单词搜索 难度:Medium 题目内容: Given a 2D board and a word, find if the word exists in the grid. The word ...
- 【剑指offer】10矩阵覆盖
原创博文,转载请注明出处! 0.简介 # 本文是牛客网<剑指offer>刷题笔记,笔记索引链接 1.题目 # 用2*1的小矩形横着或者竖着去覆盖更大的矩形.请问用n个2*1的小矩形无重叠地 ...
- 【剑指Offer】矩阵覆盖 解题报告(Python)
[剑指Offer]矩阵覆盖 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https://www.nowcoder.com/ta/coding-interviews 题目描 ...
- NOIP2002 矩形覆盖
题四 矩形覆盖(存盘名NOIPG4) [问题描述]: 在平面上有 n 个点(n <= 50),每个点用一对整数坐标表示.例如:当 n=4 时,4个点的坐标分另为:p1(1,1),p2(2,2), ...
- Hdu 1564 1*2矩阵覆盖棋局博弈
n*n的矩阵如果n为偶数 则可被1*2的矩形完全覆盖 如果n为奇数 则除起点外 其他各自可被1*2矩形完全覆盖 所以当n为偶数 先手赢 n为奇数 后手赢 #include<bits/stdc++ ...
随机推荐
- KNN-K近邻算法(1)
KNN(K-nearest neighbors) 思想简单 数学所需知识少(近零) 效果好 可解释机器学习算法使用过程中的很多细节问题 更完整的刻画机器学习应用的流程 天然可解决多分类问题 可解决回归 ...
- 【01染色法判断二分匹配+匈牙利算法求最大匹配】HDU The Accomodation of Students
http://acm.hdu.edu.cn/showproblem.php?pid=2444 [DFS染色] #include<iostream> #include<cstdio&g ...
- vue2.0一个书城实例
gitHub克隆地址 git clone https://github.com/Webxiaoyaun/vue-book.git 点击去Github下载 ## 一个书城 ## 有增加,修改,缓存,懒加 ...
- hdu - 2645 find the nearest station (bfs水)
http://acm.hdu.edu.cn/showproblem.php?pid=2645 找出每个点到距离最近的车站的距离. 直接bfs就好. #include <cstdio> #i ...
- POJ2586 Y2K Accounting Bug 解题报告
Description Accounting for Computer Machinists (ACM) has sufferred from the Y2K bug and lost some vi ...
- 洛谷—— P2543 [AHOI2004]奇怪的字符串
P2543 [AHOI2004]奇怪的字符串 题目描述 输入输出格式 输入格式: 输入文件中包含两个字符串X和Y.当中两字符串非0即1.序列长度均小于9999. 输出格式: X和Y的最长公共子序列长度 ...
- Redis基于客户端分片的集群案例(待实践)
说明: 下面的示例基本都是基于Linux去实现,目的是为了环境的统一,以便于把性能调整到最优.且基于Java.建议生产环境不要使用Windows/Mac OS这些. 在Java领域,基于客户端进行分片 ...
- 设计模式之外观模式(Facade)摘录
23种GOF设计模式一般分为三大类:创建型模式.结构型模式.行为模式. 创建型模式抽象了实例化过程,它们帮助一个系统独立于怎样创建.组合和表示它的那些对象.一个类创建型模式使用继承改变被实例化的类,而 ...
- linux系统编程:线程同步-信号量(semaphore)
线程同步-信号量(semaphore) 生产者与消费者问题再思考 在实际生活中,仅仅要有商品.消费者就能够消费,这没问题. 但生产者的生产并非无限的.比如,仓库是有限的,原材料是有限的,生产指标受消费 ...
- 传智播客ADO.Net项目开发教程具体解释
内容简单介绍: 本教程为传智播客.Net培训课堂的现场录像,请到140623ls" target="_blank">传智播客.Net学院下载很多其它免费.Net视频 ...