博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HDU 2461 Rectangles poj 3695 Rectangles
阅读量:6692 次
发布时间:2019-06-25

本文共 3286 字,大约阅读时间需要 10 分钟。

纯容斥定理:

View Code
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define LL long longusing namespace std;const int INF = 10000;class Node{public: int x1,y1,x2,y2; }node[24];int status[1250000],N;void DFS( int x1 , int y1 , int x2 , int y2 , int deep , int sign, int sta ){ if( x1 >= x2 || y1 >= y2 ) return; if( deep == N ) { if( sta !=0 ) for( int i = 1 ; i < 1 << N; i ++ ) { if( (i | sta) <= i ) status[i] += sign*( x2 - x1 ) * ( y2 - y1 ); } return ; } DFS( x1 , y1 , x2 , y2 , deep + 1, sign , sta ); DFS(max(x1,node[deep].x1),max(y1,node[deep].y1),min(x2,node[deep].x2),min(y2,node[deep].y2),deep+1,-sign,sta|(1<

优化版:

View Code
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define LL long longusing namespace std;class Node{public: int x1,y1,x2,y2;}node[24];int status[1100000],sta[100024],N,M;const int INF = 1000;void DFS( int x1,int y1,int x2,int y2 ,int deep, int s,int sign ){ if( x1>=x2 || y1 >= y2 ) return; if( deep == N ) { if( s!=0 ) { for( int i = 0; i < M; i ++ ) { if( (sta[i] | s) <= sta[i] ) { status[sta[i]] += sign*( x2 - x1 )*( y2 - y1 ); } } } return; } DFS( x1 , y1 , x2 , y2 , deep+1, s , sign ); DFS(max(x1,node[deep].x1),max(y1,node[deep].y1),min(x2,node[deep].x2),min(y2,node[deep].y2),deep+1,s|(1<

 用离散化处理:

View Code
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define LL long longusing namespace std;class Rec{public: int x1,y1,x2,y2; }rec[24],p[24];int N,M;bool cmp1( Rec a, Rec b ){ return a.y1 < b.y1;}bool cmp2( int a, int b ){ return a < b; }void Solve( ){ int num,n,cnt,left[50],right[50],tx[50],count,t; for( int k = 1 ; k <= M; k ++ ) { t = 0; count = 0;cnt=0; scanf( "%d",&n ); for( int i = 0 ; i < n ; i ++ ) { scanf( "%d",&num ); p[cnt++] = rec[num]; tx[count++] = rec[num].x1; tx[count++] = rec[num].x2; } sort( p , p + cnt , cmp1 ); sort( tx , tx + count , cmp2 ); for( int i = 1 ; i < count ; i ++ ) if( tx[i-1]!=tx[i] ) { left[t] = tx[i-1]; right[t++] = tx[i];// printf( "%d %d %d\n",left[t-1],right[t-1],t ); } int ans = 0; for( int i = 0 ; i < t ; i ++ ) { int up = -1 , down = -1; for( int j = 0 ; j < cnt ; j ++ ) { if( left[i]>=p[j].x1 && right[i]<=p[j].x2 ) { if( up < p[j].y1 ) { ans += ( right[i] - left[i] )*( up - down ); up = p[j].y2; down = p[j].y1; } else if( up < p[j].y2 ) up = p[j].y2; } } ans += ( right[i] - left[i] )*( up - down );// printf( "ans=%d %d %d %d\n",ans,up,down,right[i]- left[i] ); } printf( "Query %d: %d\n",k,ans ); } }int main( ){ int Case = 1; while( scanf( "%d%d",&N,&M ),N|M ) { for( int i = 1 ; i <= N ; i ++ ) { scanf( "%d%d%d%d",&rec[i].x1,&rec[i].y1,&rec[i].x2,&rec[i].y2 ); } printf( "Case %d:\n",Case++ ); Solve( ); puts( "" ); } //system( "pause" ); return 0;}

 

转载于:https://www.cnblogs.com/bo-tao/archive/2012/07/28/2613652.html

你可能感兴趣的文章
wordpress修改域名后的一些设置:
查看>>
VS2012 GetTickCount64
查看>>
jquery常用
查看>>
在 CentOS 7 中安装 Nextcloud
查看>>
iOS 发送邮件 ios7
查看>>
JavaMailSenderImpl
查看>>
【Android】EditText的特殊属性介绍
查看>>
go处理json格式文件
查看>>
Js针对window窗体大小设置
查看>>
MySQL 使用SELECT ... FOR UPDATE
查看>>
MYSQL级联查询,包括向上向下的级联
查看>>
Apache优化:修改最大并发连接数
查看>>
复杂软件驱动系统的UCM与UML
查看>>
【转载】安装PyInstaller的方法和遇到的问题
查看>>
SQL(mysql)通过生日字段得到年龄
查看>>
css中box-sizing的使用心得
查看>>
C# 文件下载四方法
查看>>
Spring JDBC最佳实践(3)
查看>>
windows Socket 通信模型
查看>>
jquery validate案例1
查看>>