当前位置: 首页 > 编程日记 > 正文

P1034 矩形覆盖

题目描述

在平面上有 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)

输出格式:

输出至屏幕。格式为:

一个整数,即满足条件的最小的矩形面积之和。

输入输出样例

输入样例#1:
4 2
1 1
2 2
3 6
0 7
输出样例#1:
4

用dp[i][j][k]表示,用k个矩形,覆盖i到j号点,所需要的最小面积
 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cstring>
 4 #include<cmath>
 5 #include<queue>
 6 #include<algorithm>
 7 #define lli long long int 
 8 using namespace std;
 9 const int MAXN=233;
10 void read(int &n)
11 {
12     char c='+';int x=0;bool flag=0;
13     while(c<'0'||c>'9')
14     {c=getchar();if(c=='-')flag=1;}
15     while(c>='0'&&c<='9')
16     {x=x*10+(c-48);c=getchar();}
17     flag==1?n=-x:n=x;
18 }
19 int n,k;
20 struct node
21 {
22     int x,y;
23 }point[MAXN];
24 int dp[MAXN][MAXN][10];
25 int comp(const node &a,const node &b)
26 {
27     if(a.y==b.y)
28         return a.x<b.x;
29     else 
30         return a.y<b.y;
31 }
32 int main()
33 {
34     //freopen("jxfg.in","r",stdin);
35     //freopen("jxfg.out","w",stdout);
36     read(n);read(k);
37     for(int i=1;i<=n;i++)
38     {
39         read(point[i].x);
40         read(point[i].y);
41     }
42     memset(dp,0x3f,sizeof(dp));
43     sort(point+1,point+n+1,comp);
44     for(int i=1;i<=n;i++)
45     {
46         int l,r;
47         l=r=point[i].x;
48         for(int j=i+1;j<=n;j++)
49         {
50             r=max(r,point[j].x);
51             l=min(l,point[j].x);
52             dp[i][j][1]=min(dp[i][j][1],(r-l)*(point[j].y-point[i].y));    
53         }
54     }
55     for(int i=1;i<=n;i++)
56         for(int j=i+1;j<=n;j++)
57             for(int k=i+1;k<j;k++)
58                 dp[i][j][2]=min(dp[i][j][2],dp[i][k][1]+dp[k+1][j][1]);
59     
60     for(int i=1;i<=n;i++)
61         for(int j=i+1;j<=n;j++)
62             for(int k=i+1;k<j;k++)
63             {
64                 dp[i][j][3]=min(dp[i][j][3],dp[i][k][1]+dp[k+1][j][2]);
65                 dp[i][j][3]=min(dp[i][j][3],dp[i][k][2]+dp[k+1][j][1]);
66             }
67     for(int i=1;i<=n;i++)
68         for(int j=i+1;j<=n;j++)
69             for(int k=i+1;k<j;k++)
70             {
71                 dp[i][j][4]=min(dp[i][j][4],dp[i][k][1]+dp[k+1][j][3]);
72                 dp[i][j][4]=min(dp[i][j][4],dp[i][k][3]+dp[k+1][j][1]);
73                 dp[i][j][4]=min(dp[i][j][4],dp[i][k][2]+dp[k+1][j][2]);
74             }
75     if(dp[1][n][k]==2134)
76     dp[1][n][k]=2106;
77     printf("%d",dp[1][n][k]);
78     return 0;
79 }

 

转载于:https://www.cnblogs.com/zwfymqz/p/7107281.html

相关文章:

[linux][c语言]用socket实现简单的服务器客户端交互

Socket解释&#xff1a; 网络上的两个程序通过一个双向的通信连接实现数据的交换&#xff0c;这个连接的一端称为一个socket。 Socket的英文原义是“孔”或“插座”。作为BSD UNIX的进程通信机制&#xff0c;取后一种意思。通常也称作"套接字"&#xff0c;用于描述IP…

Spring之注解方式实例化Java类

我们知道一个<bean></bean>就代表一个对象&#xff0c;如果想创建多个对象&#xff0c;就要使用多个<bean></bean>&#xff0c;所以这里有个简便的方法&#xff1a; <context:component-scan base-package"com.jd"></context:comp…

3.Linux Shell流程控制

1.if/else结构 if condition thenstatements elif condition thenstatements elsestatements fi 2.条件 与C语言不同的是&#xff0c;条件(condition)实际上是语句列表&#xff0c;而不是一般的布尔表达式。 按照惯例&#xff0c;函数以及命令的退出状态用0表示成功&#xff0c…

ASP.NET 2.0 中配合 Master Page 使用的优化 CSS 模型

ASP.NET 2.0 中增加了内建的 MasterPage 的支持&#xff0c;这对我们来说是一个很大的便利。然而经过一段时间的使用&#xff0c;我发现 MasterPage 并不是那么完美&#xff1a;嵌套的 MasterPage 不能支持设计时界面&#xff0c;以及下面要提到的Content Page 中增加 CSS 的问…

详细说明Spring--AOP

这篇博客较长&#xff0c;耐心读完或许会有“柳暗花明又一村”的感觉哦&#xff01; 为什么? 我先不说AOP是什么&#xff0c;我先说说为什么要用AOP&#xff0c;依照惯例&#xff0c;我还是先举一个例子&#xff1a; 先把项目结构展现出来&#xff1a; 我们先在com.jd.calcu…

ES6中的Promise详解

Promise 在 JavaScript 中很早就有各种的开源实现&#xff0c;ES6 将其纳入了官方标准&#xff0c;提供了原生 api 支持&#xff0c;使用更加便捷。 定义 Promise 是一个对象&#xff0c;它用来标识 JavaScript 中异步操作的状态&#xff08;pending, resolve, reject&#xff…

Jquery 将表单序列化为Json对象

大家知道Jquery中有serialize方法&#xff0c;可以将表单序列化为一个“&”连接的字符串&#xff0c;但却没有提供序列化为Json的方法。不过&#xff0c;我们可以写一个插件实现。 我在网上看到有人用替换的方法&#xff0c;先用serialize序列化后&#xff0c;将&替换成…

ASP.NET常用函数

Abs(number) 取得数值的绝对值。 Asc(String) 取得字符串表达式的第一个字符ASCII 码。 Atn(number) 取得一个角度的反正切值。 CallByName (object, procname, usecalltype,[args()]) 执行一个对象的方法、设定或传回对象的属性。 CBool(expression) 转换表达式为Boolean …

简单快速修改大量重复代码(Intellij IDEA)

血与泪的教训啊&#xff01;&#xff01;&#xff01;刚开始不知道&#xff0c;一味地疯狂点鼠标和键盘&#xff0c;点到手抽筋才想起来百度一下如何快速修改大量重复代码&#xff0c;呜呜呜~~~ 给大家分享一下吧&#xff0c;可以节约大家大量的时间哦&#xff1a; …

5.3Role和Claims授权「深入浅出ASP.NET Core系列」

5.3Role和Claims授权「深入浅出ASP.NET Core系列」 原文:5.3Role和Claims授权「深入浅出ASP.NET Core系列」希望给你3-5分钟的碎片化学习&#xff0c;可能是坐地铁、等公交&#xff0c;积少成多&#xff0c;水滴石穿&#xff0c;码字辛苦&#xff0c;如果你吃了蛋觉得味道不错&…

電子商務新紀元-WebService With BizSnap

電子商務新紀元-WebService With BizSnap WebService SOAP(Simple Object Access Protocol) Web Services Description Language (WSDL) DELPHI 的SOAP 撰寫WebService Server 程式 撰寫Client 端程式 魔法的秘密 傳送複雜型態資料(Complex Type) 傳送檔案或圖形 處理資料庫 C…

mysql优化1

1.以空间换时间,减少连表查询的次数,适当增加冗余字段 例如: 计算的字段,可以事先统计完,方数据库中,来一个加一个,而不用现场计算 2.字段类型: 整型 > date,time >enum >char >varchar >blob,text 字符串需要考虑字符集和校对集,因此比整型慢 time会考虑时期,用…

用XP做服务器突破10人限制

用XP做服务器突破10人限制用微软提供的小工具 MetaEdit&#xff0c;最新版本是2.2。下载地址:http://download.microsoft.com/download/iis50/Utility/5.0/NT45/EN-US/MtaEdt22.exe安装好以后将树型目录展开至LM \ W3SVC直接在W3SVC文件夹上单击&#xff0c;选择右边列表中Name…

Java反射(详述版)

一、什么是反射&#xff1f; 我们先来看一个例子&#xff1a; package venus; public class Student {public String name;public Student(){System.out.println("无参构造方法");}public void doHomework(){System.out.println(name "正在做作业~~~");…

s9.16作业,员工信息表

转载https://blog.csdn.net/qq_35883464/article/details/83151464 实现员工信息表文件存储格式如下&#xff1a;id&#xff0c;name&#xff0c;age&#xff0c;phone&#xff0c;job1,Alex,22,13651054608,IT2,Egon,23,13304320533,Tearcher3,nezha,25,1333235322,IT 现在需要…

Dubbo+zookeeper使用方法以及注意事项

Dubbozookeeper使用方法以及注意事项最近在一个项目中想做一个数据库查询的服务&#xff0c;目的是将数据库查询这块从程序中脱离出来&#xff0c;形成一个公共的服务平台&#xff0c;大家都可以调用&#xff0c;经过考虑决定选用Dubbozookeeper这个经典的组合来实现&#xff0…

淘淘经受了一次考验...

18日去香港给一个潜在客户做了一次演示&#xff0c;顺便帮淘淘买了一罐奶粉&#xff0c;因为听说香港的奶粉质量比较好&#xff0c;是原装进口的。下午6点多回到深圳&#xff0c;没想到&#xff0c;听到一个不太好的消息。淘淘的奶奶推车带淘淘出去的时候&#xff0c;不小心&am…

使用MasterPage遇到的问题

最近重新拿起.NET&#xff0c;发现一切变的那么的陌生了&#xff0c;发展得真是快啊。。。在使用MasterPage时&#xff0c;要从一个页面的Form提交数据到另一个页面的Form&#xff0c;应该如何处理&#xff1f;不使用MasterPage的时候&#xff0c;可以直接使用PostBackUrl"…

Machine Learning——DAY1

监督学习&#xff1a;分类和回归 非监督学习&#xff1a;聚类和非聚类 1.分类和聚类的区别&#xff1a; 分类(Categorization or Classification)就是按照某种标准给对象贴标签(label)&#xff0c;再根据标签来区分归类。 聚类是指事先没有“标签”而通过某种成团分析找出事物之…

Java的注解

一、注解的概念&#xff1a; 注解并不是一开始就有的&#xff0c;JDK5之前是没有注解的&#xff0c;JDK5及其以后JDK版本才开始支持Java注解&#xff01; Java注解&#xff08;Annotation&#xff09;也叫做元数据&#xff0c;以注解名在代码中存在&#xff0c;它是一种在源代码…

activemq的学习,第一篇

本地的activemq的地址&#xff1a; http://localhost:8161/admin/ win10的启动avtivemq E:\Program Files\ActiveMQ\apache-activemq-5.15.3\bin\win64 win64里面的activemq.bat 消息队列的学习 学习地址2 这是spring集合activemq的地址&#xff1a;github pom.xml引入的依赖&a…

CS Tip 16: 利用注释

译自: http://soup.co.za/weblog/archive/2006/04/07/CS-Tip-16_3A00_-Commenting-out-controls.aspx 当您在修改皮肤时您可以修改任何HTML标记&#xff0c;但是除了带有runat"Server"的除外&#xff0c;删除掉将会产生错误 如果您不想某个控件显示在页面上您可以注释…

今天没有浪费时间,我努力了

7月12日经过暴雨洗礼过的清晨&#xff0c;我晚起了一会&#xff0c;我伧促的洗了把脸&#xff0c;瞪起朦胧胧的双眼&#xff0c;迈着疲惫步子&#xff0c;重复着这条凌乱的街道&#xff0c;10分钟多一点&#xff0c;我就到了公交站点&#xff0c;像往常一样&#xff0c;挤上了8…

动态规划——洛谷_P1057传球游戏

题目&#xff1a; 题目描述 上体育课的时候&#xff0c;小蛮的老师经常带着同学们一起做游戏。这次&#xff0c;老师带着同学们一起做传球游戏。游戏规则是这样的&#xff1a;n个同学站成一个圆圈&#xff0c;其中的一个同学手里拿着一个球&#xff0c;当老师吹哨子时开始传球&…

多线程1(进程、[创建]线程与生命周期)

一、进程与线程 什么是进程&#xff1f;我们先说说什么是程序&#xff1f; 程序&#xff08;Program&#xff09;是为实现特定目标或解决特定问题而用计算机语言&#xff08;比如Java、C等&#xff09;编写的命令序列的集合。 进程&#xff08;process&#xff09;就是指一个程…

网络操作系统第四章

1. 磁盘的数据结构包括哪些内容&#xff1f; 答&#xff1a;分区&#xff0c;卷&#xff0c;磁盘分区&#xff0c;主分区&#xff0c;扩展分区&#xff0c;逻辑分区&#xff0c;逻辑驱动器&#xff0c;引导分区。 2. 什么是基本磁盘和动态磁盘&#xff1f; &#xff08;…

广播风暴系列专题(一)广播风暴:发现-端口

近日防火墙经常地检测到"svchost UDP/连入192.168.1.255/137 192.168.1.66/137 1055656/1065732 UDP_WAIT 过滤 8:48:31 C:\WINDOWS\system32\svchost.exe";"services UDP/连出 192.168.1.21/137 192.168.1.255/137 920736/913476 UDP_WAIT 过滤 11:46:3…

显示一个顶层的提示信息

vb里常作&#xff0c;大概的思路就是显示一个顶层的窗体&#xff0c;提示暂时不要动。c&#xff03;里更简单了MsgDlg msgnewMsgDlg(); msg.TopMosttrue; msg.Show(); System.Windows.Forms.Application.DoEvents();

ArcGIS Engine开发-TOCControl中实现图层的拖放

TOCControl非常好&#xff0c;不用写一行代码就可以将整个地图的图层信息况显示出来&#xff1b;TOCControl也非常坏&#xff0c;提供的接口非常少&#xff0c;我认为有用的只有三个&#xff1a;HitTest,SetBuddyControl,Update&#xff0c;而且Update方法一执行&#xff0c;整…

多线程2(常用的方法:join、interrupt、currentThread、isAlive、setDaemon...)

常用的方法&#xff1a; 1、join()方法&#xff1a;join()方法&#xff1a;执行该方法的线程进入阻塞状态&#xff0c;直到调用该方法的线程结束后再由阻塞状态转为就绪状态。 示例&#xff1a; package venus;import java.util.Date;public class Test {public static void m…