uva11983扫描线k次覆盖
自己做的是从下往上扫描的,一直wa,不知道坑在哪里。。但是作为模板。我还是找了份不错的ac代码
/*
被覆盖不低于k次的点
每个点对应了一个单位面积,本题把点转面积即是被覆盖不低于k次的面积
可以当做求k次面积覆盖模板的题目!
*/
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<map>
using namespace std;
#define maxn 60005
#define lson l,m,rt<<1
#define rson m,r,rt<<1|1
#define ll long long
int n,k;
struct Seg{
int l,r,h,c;
Seg(){}
Seg(int l,int r,int h,int c):l(l),r(r),h(h),c(c){}
bool operator<(const Seg& a)const {
return h<a.h;
}
}segs[maxn];
int tot,totx,x[maxn];//线段树建立在x轴上
int len[maxn<<][],flag[maxn<<];
map<int,int>mp; inline void pushup(int rt,int l,int r){
if(flag[rt]>=k){
for(int i=;i<=k;i++) len[rt][i]=;
len[rt][k]=x[r]-x[l]; }
else if(flag[rt]>){
int cur=flag[rt];//当前区间覆盖次数
for(int i=;i<=k;i++) len[rt][i]=;//先把当前区间所有覆盖情况置零
len[rt][cur]=x[r]-x[l];
if(l+==r) return; for(int i=;i<=k;i++){
if(i+cur>=k) len[rt][k]+=len[rt<<][i]+len[rt<<|][i];
else len[rt][i+cur]+=len[rt<<][i]+len[rt<<|][i];
}
for(int i=cur+;i<=k;i++)
len[rt][cur]-=len[rt][i];
}
else {
for(int i=;i<=k;i++) len[rt][i]=;
if(l+==r) return;
for(int i=;i<=k;i++)
len[rt][i]=len[rt<<][i]+len[rt<<|][i];
}
}
void update(int L,int R,int c,int l,int r,int rt){
if(L<=l && R>=r){
flag[rt]+=c;;
pushup(rt,l,r);
return;
}
int m=l+r>>;
if(L<m) update(L,R,c,lson);
if(R>m) update(L,R,c,rson);
pushup(rt,l,r);
} void init(){
tot=totx=;
mp.clear();
memset(len,,sizeof len);
memset(flag,,sizeof flag);
}
int main(){
int T,a,b,c,d;
cin >> T;
for(int tt=;tt<=T;tt++){
init();
scanf("%d%d",&n,&k);
for(int i=;i<n;i++){
scanf("%d%d%d%d",&a,&b,&c,&d);
c++;d++;
segs[tot++]=Seg(a,c,b,);
segs[tot++]=Seg(a,c,d,-);
x[totx++]=a;x[totx++]=c;
}
sort(x,x+totx);
sort(segs,segs+tot);
totx=unique(x,x+totx)-x;
for(int i=;i<totx;i++) mp[x[i]]=i; ll res=;
for(int i=;i<tot;i++){
if(i!=)
res+=(segs[i].h-segs[i-].h)*len[][k];
// cout<<segs[i].h-segs[i-1].h<< " "<<len[1][k]<<'\n';
update(mp[segs[i].l],mp[segs[i].r],segs[i].c,,totx-,); }
printf("Case %d: %lld\n",tt,res);
}
return ;
}
uva11983扫描线k次覆盖的更多相关文章
- HDU 4862 Jump(最小K路径覆盖)
输入一个n×m网格图,每个结点的值为0-9,可以从任意点出发不超过k次,走完每个点且仅访问每个结点一次,问最终的能量最大值.不可全部走完的情况输出-1. 初始能量为0. 而结点(x,y)可以跳跃到结点 ...
- 网络费用流-最小k路径覆盖
多校联赛第一场(hdu4862) Jump Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- UVA-11983-Weird Advertisement(线段树+扫描线)[求矩形覆盖K次以上的面积]
题意: 求矩形覆盖K次以上的面积 分析: k很小,可以开K颗线段树,用sum[rt][i]来保存覆盖i次的区间和,K次以上全算K次 // File Name: 11983.cpp // Author: ...
- Comet OJ 茶颜悦色 线段树+扫描线(矩形覆盖最多点+优化)
题目:https://www.cometoj.com/contest/59/problem/D?problem_id=2713 题意:给你一个正方形,然后给你n个点,这个正方形能随意放哪,要求那个正方 ...
- POJ 2482 扫描线(面积覆盖最大次数)
Stars in Your Window Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10806 Accepted: ...
- hdu 4862 KM算法 最小K路径覆盖的模型
http://acm.hdu.edu.cn/showproblem.php?pid=4862 选t<=k次,t条路要经过全部的点一次而且只一次. 建图是问题: 我自己最初就把n*m 个点分别放入 ...
- [LeetCode] 632. Smallest Range Covering Elements from K Lists 覆盖K个列表元素的最小区间
You have k lists of sorted integers in ascending order. Find the smallest range that includes at lea ...
- POJ 3261 字符串上的k次覆盖问题
题目大意: 给定一个数组,求一个最大的长度的子串至少出现过k次 一个子串出现多次,也就是说必然存在2个子串间的前缀长度为所求的值 通过二分答案,通过线性扫一遍,去判断出现次数,也就是说每次遇见一个he ...
- poj3680 Intervals 区间k覆盖问题 最小费用最大流 建图巧妙
/** 题目:poj3680 Intervals 区间k覆盖问题 最小费用最大流 建图巧妙 链接:http://poj.org/problem?id=3680 题意:给定n个区间,每个区间(ai,bi ...
随机推荐
- H5新特性之拖拽文件
H5新增了drag事件,在H5中拖拽是十分常见的. 可以拖拽的分为页面内的和页面外的 页面内的一般默认可以拖拽的是img和a标签 页面外的常指的是文件 上代码吧~ let zoom = documen ...
- SQL连接服务器链接失败
链接服务器"AGPSServer"的 OLE DB 访问接口 "SQLNCLI10" 返回了消息 "登录超时已过期".链接服务器" ...
- PostgreSQL操作-psql基本命令
一.建立数据库连接----------------接入PostgreSQL数据库: psql -h IP地址 -p 端口 -U 数据库名 之后会要求输入数据库密码 二.访问数据库 1.列举数据库:\l ...
- 跳表,Redis 为什么用跳表而不用平衡树?
https://juejin.im/post/57fa935b0e3dd90057c50fbc 在 Redis 中,list 有两种存储方式:双链表(LinkedList)和压缩双链表(ziplist ...
- Solr之java操作
参考教程: http://www.cnblogs.com/xia520pi/p/3625232.html http://www.cnblogs.com/hujunzheng/p/5647896.htm ...
- 六、uboot 代码流程分析---start.S
6.1 _start 入口函数 6.1.1 vectors.S (arch\arm\lib) 从上一节可以知道,uboot 的入口函数为 _start .此 函数定义在 vectors.S (arch ...
- asp.net mvc简单分页实例
@{ ViewBag.Title = "Index"; } @{ int pageIndex = (int)ViewBag.CurrentPage; int pageCount = ...
- js设置div透明度
原生js设置透明度 为了兼容IE与其他浏览器对透明度的设置,我们需要对以上两种样式分别进行设置: 复制代码代码如下: var alpha = 30; //透明度值变量 var oDiv = docum ...
- JavaJavaScript之内存与变量初始化
0.搞清三个概念:预加载与执行期:js变量存储(栈区与堆区):js变量的类型(引用类型(对象)与基本数据类型); JS在预编译时,对于函数的预加载方面,浏览器仅仅选择编译声明式函数(function ...
- History API:ScrollRestoration
By Paul Lewis(设计和性能倡导者) 翻译:江天 使用history api管理url是非常棒的一件事,可以说这是一个好web app的极为重要的特点.但它有一个缺点,滚动位置虽然被存储 ...