hdu 4268 Alice and Bob(multiset|段树)

hdu 4268 Alice and Bob(multiset|段树)

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

Alice and Bob

Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 2901    Accepted Submission(s): 941

Problem Description
Alice and Bob’s game never ends. Today, they introduce a new game. In this game, both of them have N different rectangular cards respectively. Alice wants to use his cards to cover Bob’s. The card A can cover the card B if the height of A is not smaller than B and the width of A is not smaller than B. As the best programmer, you are asked to compute the maximal number of Bob’s cards that Alice can cover.

Please pay attention that each card can be used only once and the cards cannot be rotated.

 

Input
The first line of the input is a number T (T <= 40) which means the number of test cases.

For each case, the first line is a number N which means the number of cards that Alice and Bob have respectively. Each of the following N (N <= 100,000) lines contains two integers h (h <= 1,000,000,000) and w (w <= 1,000,000,000) which means the height and width of Alice’s card, then the following N lines means that of Bob’s.

 

Output
For each test case, output an answer using one line which contains just one number.

 

Sample Input
   
   
2 2 1 2 3 4 2 3 4 5 3 2 3 5 7 6 8 4 1 2 5 3 4

 

Sample Output
   
   
1 2

 

Source

Recommend
 
题意:
A,B两个人各有n个矩形。

(n<=1e5)如今A想用自己的矩形覆盖B的矩形。一个矩形覆盖还有一个矩形的条件是宽和高都不还有一个矩形相应的宽和高小。如今问A最多能覆盖B的多少个矩形。每一个矩形最多覆盖一个还有一个矩形。且矩形不能旋转。

思路:
就是贪心的思想。先把两个人的矩形都按w排序。

然后对于A的每个矩形。找一个w<=自己w.h<自己H且尽量接近的B的矩形覆盖即可了。

覆盖后删除这两个矩形。对于找上述条件的矩形能够用multiset维护。

可是比赛时换了种姿势用线段树写了发。

思路都差点儿相同。离散化。维护区间和。找小于等于p且最靠右的位置。

具体见代码:

#include <iostream>
#include<stdio.h>
#include<algorithm>
using namespace std;
#define lson L,mid,ls
#define rson mid+1,R,rs
const int maxn=100010;
int num[maxn<<3];//离散化后有2*n忘了改大空间了。

坑struct node{ int w,h;} ag[maxn],bg[maxn];int H[maxn<<1];inline bool cmp(const node &a,const node &b){ if(a.w==b.w) return a.h<b.h; return a.w<b.w;}void build(int L,int R,int rt){ num[rt]=0; if(L==R) return ; int ls=rt<<1,rs=ls|1,mid=(L+R)>>1; build(lson); build(rson);}void update(int L,int R,int rt,int p,int d){ if(L==R) { num[rt]+=d; return; } int ls=rt<<1,rs=ls|1,mid=(L+R)>>1; if(p<=mid) update(lson,p,d); else update(rson,p,d); num[rt]=num[ls]+num[rs];}int qu(int L,int R,int rt,int p){ if(!num[rt]) return -1; if(L==R) return L; int ls=rt<<1,rs=ls|1,mid=(L+R)>>1,pos=-1; if(p<=mid) return qu(lson,p); if(num[rs]) pos=qu(rson,p); if(pos!=-1) return pos; return qu(lson,p);}int main(){ int t,n,i,m,p,ans; scanf("%d",&t); while(t--) { m=0; scanf("%d",&n); for(i=0;i<n;i++) { scanf("%d%d",&ag[i].h,&ag[i].w); H[m++]=ag[i].h; } for(i=0;i<n;i++) { scanf("%d%d",&bg[i].h,&bg[i].w); H[m++]=bg[i].h; } sort(ag,ag+n,cmp); sort(bg,bg+n,cmp); sort(H,H+m); m=unique(H,H+m)-H; build(1,m,1); ans=p=0; for(i=0;i<n;i++) { while(p<n&&bg[p].w<=ag[i].w) update(1,m,1,lower_bound(H,H+m,bg[p].h)-H+1,1),p++; int pos=qu(1,m,1,lower_bound(H,H+m,ag[i].h)-H+1); if(pos!=-1) { ans++; update(1,m,1,pos,-1); } } printf("%d\n",ans); } return 0;}

版权声明:本文博主原创文章,博客,未经同意不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116762.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 细数家庭安防五大乱象 何时能步入正轨

    细数家庭安防五大乱象 何时能步入正轨虽然智能家居行业在我国的成长已逾十个年头了,但是目前市场离成型仍然有一段距离。市场上可谓“乱象”丛生,这些绊脚石严重阻碍了行业的良性发展。市场乱象繁生,智能家居从概念炒作到价格高抬,相关预测显示,若真如电商一样打起价格战,智能家居就要认输了。“智能家居”(SmartHome)最早被提出和应用是在上世纪80年代的欧美和日本,2000年才被引入中国。世纪…

    2022年6月22日
    21
  • java单例模式代码实现方式_java单例模式实现方式

    java单例模式代码实现方式_java单例模式实现方式JAVA常见的设计模式之单例模式 懒汉模式 懒汉式是典型的时间换空间,也就是每次获取实例都会进行判断,看是否需要创建实例,浪费判断的时间。当然,如果一直没有人使用的话,那就不会创建实例,则节约内存空间(搬运工)。标准的懒汉模式classLazySingleton{//私有成员属性privateLazySingletonlazySingleton;//私有构造方法privateLazySingleto…

    2022年8月11日
    10
  • ODT_ODT2是什么意思

    ODT_ODT2是什么意思ODT练手CF915E题意:Q次区间(1~n)操作,k=2区间(l,r)变为1,k=1区间(l,r)变为0,一开始全是1问每次操作后1的数目n<=1e9Q<=1e5#include<bits/stdc++.h>usingnamespacestd;#definelllonglongllqmod(lla,llb,llmod){…

    2022年9月10日
    0
  • 下载mysql驱动jar包

    下载mysql驱动jar包MYSQL官网历史驱动Jar包下载地址:https://downloads.mysql.com/archives/c-j/ProductVersion选择mysql版本,OperatingSystem选择PlatformIndepen,然后下载即可

    2022年5月11日
    39
  • android 100以内的随机数

    android 100以内的随机数int a = (int)(Math.random()*100);//a是已经生成的随机数

    2022年7月17日
    16
  • SIGPIPE[通俗易懂]

    SIGPIPE[通俗易懂]当服务器close一个连接时,若client端接着发数据。根据TCP协议的规定,会收到一个RST响应,client再往这个服务器发送数据时,系统会发出一个SIGPIPE信号给进程,告诉进程这个连接已经断开了,不要再写了。我写了一个服务器程序,在Linux下测试,然后用C++写了客户端用千万级别数量的短链接进行压力测试.  但是服务器总是莫名退出,没有core文件.最后问题确

    2022年5月7日
    42

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号