51nod 1480 打广告(二分+线段树)
题意
给出n个区间和m个区间,从这n个区间里选一个区间a,这m个区间选一个区间b,使得a&b的长度*c最大。
思路
如果这n个区间里有一个区间包含另一个区间,那另外一个区间就可以忽略掉,进行\(O(nlogn)\)去重之后,剩下的区间按左端>点递增的方式排序后的右端点一定也是递增的。
问题变成了对m个区间中的每一个都寻找一个在n个区间里的区间,使得区间交最大。
通过二分两次,可以找到区间相交的最优区间。
剩下的就是在区间内部的区间,用线段树可以做到\(O(mlogn)\)
总复杂度\(O((n+m)logn)\)。
代码
# include <bits/stdc++.h>
using namespace std;
# define lowbit(x) ((x)&(-x))
const double pi=acos(-1.0);
# define eps 1e-8
# define MOD 1000000007
# define INF 1000000000
# define mem(a,b) memset(a,b,sizeof(a))
# define FOR(i,a,n) for(int i=a; i<=n; ++i)
# define FDR(i,a,n) for(int i=a; i>=n; --i)
# define bug puts("H");
# define lch p<<1,l,mid
# define rch p<<1|1,mid+1,r
# define mp make_pair
# define pb push_back
typedef pair<int,int> PII;
typedef vector<int> VI;
# pragma comment(linker, "/STACK:1024000000,1024000000")
typedef long long LL;
inline char nc(){
static char buf[100000],*p1=buf,*p2=buf;
return p1==p2&&(p2=(p1=buf)+fread(buf,1,100000,stdin),p1==p2)?EOF:*p1++;
}
inline int Scan(){
char ch=nc();int sum=0;
while(!(ch>='0'&&ch<='9'))ch=nc();
while(ch>='0'&&ch<='9')sum=sum*10+ch-48,ch=nc();
return sum;
}
const int N=200005;
//Code begin....
struct Node{int l, r;}node[N];
int p[N], seg[N<<2];
bool comp(Node a, Node b){return a.l!=b.l?a.l<b.l:a.r>b.r;}
LL operator&(Node a, Node b){
if (a.l<=b.l&&a.r>=b.r) return b.r-b.l;
if (a.l>=b.l&&a.r<=b.r) return a.r-a.l;
return max(min(a.r,b.r)-max(a.l,b.l),0);
}
void push_up(int p){seg[p]=max(seg[p<<1],seg[p<<1|1]);}
void init(int p, int l, int r){
if (l<r) {
int mid=(l+r)>>1;
init(lch); init(rch); push_up(p);
}
else seg[p]=node[l].r-node[l].l;
}
LL query(int p, int l, int r, int L, int R){
if (L>r||R<l) return 0;
if (L<=l&&R>=r) return seg[p];
else {
int mid=(l+r)>>1;
return max(query(lch,L,R),query(rch,L,R));
}
}
int main ()
{
int n, m, a, b, c;
LL ans=0;
n=Scan(); m=Scan();
FOR(i,1,n) node[i].l=Scan(), node[i].r=Scan();
sort(node+1,node+n+1,comp);
int pos=1;
FOR(i,2,n) if (node[i].r>node[pos].r) node[++pos]=node[i];
init(1,1,pos);
FOR(i,1,m) {
a=Scan(); b=Scan(); c=Scan();
int l=1, r=pos+1, mid, L, R;
while (l<r) {
mid=(l+r)>>1;
if (l==mid) break;
if (node[mid].l<a) l=mid;
else r=mid;
}
ans=max(ans,(Node{a,b}&node[l])*c);
L=l+1; l=1; r=pos+1;
while (l<r) {
mid=(l+r)>>1;
if (node[mid].r>b) r=mid;
else l=mid+1;
}
ans=max(ans,(Node{a,b}&node[r])*c);
R=r-1;
if (R>=L) ans=max(ans,query(1,1,pos,L,R)*c);
}
cout<<ans<<endl;
return 0;
}
51nod 1480 打广告(二分+线段树)的更多相关文章
- HDU4614 Vases and Flowers 二分+线段树
分析:感觉一看就是二分+线段树,没啥好想的,唯一注意,当开始摆花时,注意和最多能放的比大小 #include<iostream> #include<cmath> #includ ...
- 51nod 1364 最大字典序排列(线段树)
1364 最大字典序排列基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 给出一个1至N的排列,允许你做不超过K次操作,每次操作可以将相邻的两个数交换,问能够得到的字 ...
- J - Joseph and Tests Gym - 102020J (二分+线段树)
题目链接:https://cn.vjudge.net/contest/283920#problem/J 题目大意:首先给你n个门的高度,然后q次询问,每一次询问包括两种操作,第一种操作是将当前的门的高 ...
- Educational Codeforces Round 61 D 二分 + 线段树
https://codeforces.com/contest/1132/problem/D 二分 + 线段树(弃用结构体型线段树) 题意 有n台电脑,只有一个充电器,每台电脑一开始有a[i]电量,每秒 ...
- 【BZOJ-3110】K大数查询 整体二分 + 线段树
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6265 Solved: 2060[Submit][Sta ...
- hdu6070 Dirt Ratio 二分+线段树
/** 题目:hdu6070 Dirt Ratio 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6070 题意:给定n个数,求1.0*x/y最小是多少.x ...
- K-th occurrence HDU - 6704 (后缀数组+二分线段树+主席树)
大意: 给定串s, q个询问(l,r,k), 求子串s[l,r]的第kk次出现位置. 这是一篇很好的题解: https://blog.csdn.net/sdauguanweihong/article/ ...
- 51nod1287(二分/线段树区间最值&单点更新)
题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1287 题意:中文题诶- 解法1:b[i] 存储 max(a[0 ...
- HDU5008 Boring String Problem(后缀数组 + 二分 + 线段树)
题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5008 Description In this problem, you are given ...
随机推荐
- Python2.7-marshal
marshal模块,和 pickle 模块功能基本相同,也是序列化数据,只不过 marshal 都序列化成二进制数据,由于没有官方统一,不同版本 marshal 的结果也会不一样,所以不推荐使用.ma ...
- windows10 安装 Anaconda 并配置 pytorch1.0
官网下载Anaconda安装包,按步骤安装即可安装完后,打开DOS,或Anaconda自带的Anaconda Prompt终端查看Anaconda已安装的安装包C:\Users\jiangshan&g ...
- JAVA框架 Spring 注解注入
一.首先需要引入jar包:spring-aop-4.2.4.RELEASE.jar.(在spring解压包libs内). 二.如果注解方式注入依赖的对象,需要引用新的约束. 内的:xsd-config ...
- 解决IDEA因分配内存而引起的卡顿
解决IDEA分配内存不足引起卡顿的问题 在使用IDEA的过程中,经常会运行一段时间后程序卡顿.一段代码可能要敲很久或者出现死机状态,严重影响代码书写速度.经查阅资料,IDEA的自动分配内存最大只有75 ...
- C++之语言概述
C++语言是广泛使用的程序设计语言之一,因其特有的优势在计算机应用领域占有重要一席. C语言的发展 20世纪70年代初,贝尔实验室的Dennis Richie 等人在B语言基础上开发出C语言,最初是作 ...
- Android Fragment(二)
废话:在上一篇的博客中我们给出了Fragment的简单介绍,这一片博客给大家介绍一下Fragment到底该怎样用.主要都用在哪方面等等. 需求:现有一个界面,要求,竖屏时界面的背景颜色为红色,横屏时界 ...
- solr服务器搭建与Tomact整合及使用
一:solr服务器的搭建 1:搭建全新的为solr专用的solr服务器: 在自己电脑上搭建两台Tomact服务器,一台仍为应用服务器,一台作为solr服务器,应用服务器按照正常Tomact服务器搭建即 ...
- Bluedroid协议栈HCI线程分析
蓝牙进程中有多个线程,其中HCI 线程是负责处理蓝牙主机端和控制器的数据处理和收发的工作. 本篇文章就是分析一下该线程的数据处理流程. 1.跟HCI相关的接口 首先看看hci的相关的接口:在hci_l ...
- 解决 引入本地jar包后 maven无法编译的问题及部署war包缺失本地jar包的问题
参考:https://blog.csdn.net/wang864676212/article/details/82626922 pom.xml 引入 <plugin> <plugin ...
- WayOS计费对接(零点计费系统)详细教程
零点计费系统开发也有两年了,一直都是自己和朋友在使用,今年开始有对外免费开发体验的想法,在此简单介绍一下wayos和零点计费的对接教程. 可到官网www.feidian8.com里面的首页点击查看零点 ...